grpc 1.0.1 → 1.1.2
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 +3696 -867
- data/etc/roots.pem +39 -111
- data/include/grpc/byte_buffer.h +64 -1
- data/include/grpc/census.h +40 -96
- data/include/grpc/compression.h +2 -1
- data/include/grpc/grpc.h +42 -7
- data/include/grpc/grpc_posix.h +8 -5
- data/include/grpc/impl/codegen/atm.h +3 -0
- data/include/grpc/impl/codegen/atm_gcc_atomic.h +2 -0
- data/include/grpc/impl/codegen/atm_gcc_sync.h +8 -0
- data/include/grpc/impl/codegen/atm_windows.h +4 -0
- data/include/grpc/impl/codegen/byte_buffer_reader.h +4 -4
- data/include/grpc/impl/codegen/compression_types.h +1 -1
- data/include/grpc/impl/codegen/connectivity_state.h +2 -0
- data/include/grpc/impl/codegen/exec_ctx_fwd.h +41 -0
- data/include/grpc/impl/codegen/gpr_slice.h +84 -0
- data/include/grpc/impl/codegen/{alloc.h → gpr_types.h} +30 -29
- data/include/grpc/impl/codegen/grpc_types.h +91 -9
- data/include/grpc/impl/codegen/port_platform.h +25 -92
- data/include/grpc/impl/codegen/slice.h +54 -97
- data/include/grpc/impl/codegen/sync.h +0 -253
- data/include/grpc/module.modulemap +0 -2
- data/include/grpc/slice.h +132 -0
- data/include/grpc/{impl/codegen/slice_buffer.h → slice_buffer.h} +22 -39
- data/include/grpc/support/alloc.h +40 -1
- data/include/grpc/support/log.h +80 -1
- data/include/grpc/support/log_windows.h +2 -0
- data/include/grpc/support/string_util.h +1 -1
- data/include/grpc/support/sync.h +252 -0
- data/include/grpc/support/time.h +67 -1
- data/src/boringssl/err_data.c +639 -627
- data/src/core/ext/census/base_resources.c +71 -0
- data/src/core/ext/census/base_resources.h +39 -0
- data/src/core/ext/census/gen/census.pb.c +26 -29
- data/src/core/ext/census/gen/census.pb.h +68 -67
- data/src/core/ext/census/gen/trace_context.pb.c +81 -0
- data/src/core/ext/census/gen/trace_context.pb.h +99 -0
- data/src/core/ext/census/grpc_filter.c +22 -16
- data/src/core/ext/census/grpc_plugin.c +2 -1
- data/src/core/ext/census/initialize.c +16 -4
- data/src/core/ext/census/mlog.h +1 -1
- data/src/core/ext/census/placeholders.c +0 -45
- data/src/core/ext/census/resource.c +312 -0
- data/src/core/ext/census/resource.h +63 -0
- data/src/core/ext/census/trace_context.c +86 -0
- data/src/core/ext/census/trace_context.h +68 -0
- data/src/core/ext/census/tracing.c +8 -2
- data/src/core/ext/{client_config → client_channel}/channel_connectivity.c +8 -4
- data/src/core/ext/client_channel/client_channel.c +1218 -0
- data/src/core/ext/{client_config → client_channel}/client_channel.h +8 -11
- data/src/core/ext/{client_config → client_channel}/client_channel_factory.c +33 -3
- data/src/core/ext/{client_config → client_channel}/client_channel_factory.h +15 -8
- data/src/core/ext/{client_config/client_config_plugin.c → client_channel/client_channel_plugin.c} +16 -15
- data/src/core/ext/{client_config → client_channel}/connector.c +1 -1
- data/src/core/ext/{client_config → client_channel}/connector.h +5 -8
- data/{include/grpc/support/slice_buffer.h → src/core/ext/client_channel/default_initial_connect_string.c} +4 -5
- data/src/core/ext/client_channel/http_connect_handshaker.c +399 -0
- data/src/core/ext/client_channel/http_connect_handshaker.h +52 -0
- data/src/core/ext/{client_config → client_channel}/initial_connect_string.c +6 -7
- data/src/core/ext/{client_config → client_channel}/initial_connect_string.h +10 -10
- data/src/core/ext/{client_config → client_channel}/lb_policy.c +11 -11
- data/src/core/ext/{client_config → client_channel}/lb_policy.h +68 -27
- data/src/core/ext/client_channel/lb_policy_factory.c +163 -0
- data/src/core/ext/{client_config → client_channel}/lb_policy_factory.h +64 -9
- data/src/core/ext/{client_config → client_channel}/lb_policy_registry.c +6 -4
- data/src/core/ext/{client_config → client_channel}/lb_policy_registry.h +4 -4
- data/src/core/ext/{client_config → client_channel}/parse_address.c +21 -14
- data/src/core/ext/{client_config → client_channel}/parse_address.h +8 -10
- data/src/core/ext/{client_config → client_channel}/resolver.c +3 -4
- data/src/core/ext/{client_config → client_channel}/resolver.h +11 -15
- data/src/core/ext/{client_config → client_channel}/resolver_factory.c +4 -3
- data/src/core/ext/{client_config → client_channel}/resolver_factory.h +13 -11
- data/src/core/ext/{client_config → client_channel}/resolver_registry.c +54 -34
- data/src/core/ext/{client_config → client_channel}/resolver_registry.h +21 -8
- data/src/core/ext/{client_config → client_channel}/subchannel.c +208 -119
- data/src/core/ext/{client_config → client_channel}/subchannel.h +21 -11
- data/src/core/ext/{client_config → client_channel}/subchannel_index.c +6 -17
- data/src/core/ext/{client_config → client_channel}/subchannel_index.h +7 -7
- data/src/core/ext/{client_config → client_channel}/uri_parser.c +21 -28
- data/src/core/ext/{client_config → client_channel}/uri_parser.h +3 -3
- data/src/core/ext/lb_policy/grpclb/grpclb.c +1406 -0
- data/src/core/ext/lb_policy/grpclb/grpclb.h +44 -0
- data/src/core/ext/lb_policy/grpclb/load_balancer_api.c +117 -37
- data/src/core/ext/lb_policy/grpclb/load_balancer_api.h +31 -12
- data/src/core/ext/lb_policy/grpclb/proto/grpc/lb/v1/load_balancer.pb.c +6 -36
- data/src/core/ext/lb_policy/grpclb/proto/grpc/lb/v1/load_balancer.pb.h +22 -42
- data/src/core/ext/lb_policy/pick_first/pick_first.c +64 -46
- data/src/core/ext/lb_policy/round_robin/round_robin.c +324 -160
- data/src/core/ext/load_reporting/load_reporting.c +7 -56
- data/src/core/ext/load_reporting/load_reporting.h +41 -28
- data/src/core/ext/load_reporting/load_reporting_filter.c +132 -42
- data/src/core/ext/load_reporting/load_reporting_filter.h +1 -0
- data/src/core/ext/resolver/dns/native/dns_resolver.c +88 -80
- data/src/core/ext/resolver/sockaddr/sockaddr_resolver.c +57 -102
- data/src/core/ext/transport/chttp2/alpn/alpn.c +1 -1
- data/src/core/ext/transport/chttp2/client/chttp2_connector.c +253 -0
- data/src/core/{lib/iomgr/ev_poll_and_epoll_posix.h → ext/transport/chttp2/client/chttp2_connector.h} +5 -5
- data/src/core/ext/transport/chttp2/client/insecure/channel_create.c +31 -160
- data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.c +5 -5
- data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.c +44 -243
- data/src/core/ext/transport/chttp2/server/chttp2_server.c +342 -0
- data/src/core/ext/transport/chttp2/server/chttp2_server.h +47 -0
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.c +11 -124
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.c +20 -9
- data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.c +28 -236
- data/src/core/ext/transport/chttp2/transport/bin_decoder.c +31 -27
- data/src/core/ext/transport/chttp2/transport/bin_decoder.h +5 -4
- data/src/core/ext/transport/chttp2/transport/bin_encoder.c +25 -22
- data/src/core/ext/transport/chttp2/transport/bin_encoder.h +8 -7
- data/src/core/ext/transport/chttp2/transport/chttp2_plugin.c +0 -3
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.c +1345 -1521
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +3 -1
- data/src/core/ext/transport/chttp2/transport/frame.h +3 -5
- data/src/core/ext/transport/chttp2/transport/frame_data.c +50 -47
- data/src/core/ext/transport/chttp2/transport/frame_data.h +8 -9
- data/src/core/ext/transport/chttp2/transport/frame_goaway.c +19 -21
- data/src/core/ext/transport/chttp2/transport/frame_goaway.h +9 -8
- data/src/core/ext/transport/chttp2/transport/frame_ping.c +13 -12
- data/src/core/ext/transport/chttp2/transport/frame_ping.h +6 -6
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.c +31 -19
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +8 -7
- data/src/core/ext/transport/chttp2/transport/frame_settings.c +22 -25
- data/src/core/ext/transport/chttp2/transport/frame_settings.h +9 -8
- data/src/core/ext/transport/chttp2/transport/frame_window_update.c +26 -18
- data/src/core/ext/transport/chttp2/transport/frame_window_update.h +5 -6
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.c +68 -58
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +8 -5
- data/src/core/ext/transport/chttp2/transport/hpack_parser.c +327 -214
- data/src/core/ext/transport/chttp2/transport/hpack_parser.h +14 -9
- data/src/core/ext/transport/chttp2/transport/hpack_table.c +24 -19
- data/src/core/ext/transport/chttp2/transport/hpack_table.h +9 -6
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.c +2 -2
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.h +1 -1
- data/src/core/ext/transport/chttp2/transport/internal.h +284 -436
- data/src/core/ext/transport/chttp2/transport/parsing.c +355 -590
- data/src/core/ext/transport/chttp2/transport/stream_lists.c +36 -309
- data/src/core/ext/transport/chttp2/transport/stream_map.c +13 -34
- data/src/core/ext/transport/chttp2/transport/stream_map.h +3 -4
- data/src/core/ext/transport/chttp2/transport/writing.c +174 -286
- data/src/core/lib/channel/channel_args.c +70 -13
- data/src/core/lib/channel/channel_args.h +28 -2
- data/src/core/lib/channel/channel_stack.c +77 -28
- data/src/core/lib/channel/channel_stack.h +61 -23
- data/src/core/lib/channel/channel_stack_builder.c +33 -25
- data/src/core/lib/channel/channel_stack_builder.h +17 -8
- data/src/core/lib/channel/compress_filter.c +52 -36
- data/src/core/lib/channel/connected_channel.c +20 -12
- data/src/core/lib/channel/connected_channel.h +2 -1
- data/src/core/lib/channel/context.h +13 -1
- data/src/core/lib/channel/deadline_filter.c +344 -0
- data/src/core/lib/channel/deadline_filter.h +99 -0
- data/src/core/lib/channel/handshaker.c +240 -0
- data/src/core/lib/channel/handshaker.h +164 -0
- data/src/core/lib/{security/credentials/google_default/credentials_windows.c → channel/handshaker_factory.c} +16 -23
- data/src/core/lib/channel/handshaker_factory.h +66 -0
- data/src/core/lib/channel/handshaker_registry.c +113 -0
- data/src/core/{ext/client_config/client_config.h → lib/channel/handshaker_registry.h} +26 -16
- data/src/core/lib/channel/http_client_filter.c +248 -46
- data/src/core/lib/channel/http_client_filter.h +3 -0
- data/src/core/lib/channel/http_server_filter.c +136 -24
- data/src/core/lib/channel/message_size_filter.c +261 -0
- data/src/core/lib/channel/message_size_filter.h +39 -0
- data/src/core/lib/compression/message_compress.c +43 -37
- data/src/core/lib/compression/message_compress.h +7 -5
- data/src/core/lib/http/format_request.c +26 -11
- data/src/core/lib/http/format_request.h +7 -5
- data/src/core/lib/http/httpcli.c +45 -27
- data/src/core/lib/http/httpcli.h +4 -4
- data/src/core/lib/http/httpcli_security_connector.c +56 -46
- data/src/core/lib/http/parser.c +17 -14
- data/src/core/lib/http/parser.h +4 -2
- data/src/core/lib/iomgr/closure.c +49 -7
- data/src/core/lib/iomgr/closure.h +56 -14
- data/src/core/lib/iomgr/combiner.c +422 -0
- data/src/core/lib/iomgr/combiner.h +64 -0
- data/src/core/lib/iomgr/endpoint.c +8 -2
- data/src/core/lib/iomgr/endpoint.h +17 -7
- data/src/core/lib/iomgr/endpoint_pair.h +3 -2
- data/src/core/lib/iomgr/endpoint_pair_posix.c +9 -8
- data/src/core/{ext/client_config/lb_policy_factory.c → lib/iomgr/endpoint_pair_uv.c} +18 -13
- data/src/core/lib/iomgr/endpoint_pair_windows.c +7 -6
- data/src/core/lib/iomgr/error.c +72 -6
- data/src/core/lib/iomgr/error.h +30 -3
- data/src/core/lib/iomgr/ev_epoll_linux.c +500 -382
- data/src/core/lib/iomgr/ev_epoll_linux.h +3 -2
- data/src/core/lib/iomgr/ev_poll_posix.c +317 -30
- data/src/core/lib/iomgr/ev_poll_posix.h +1 -0
- data/src/core/lib/iomgr/ev_posix.c +26 -5
- data/src/core/lib/iomgr/ev_posix.h +12 -1
- data/src/core/lib/iomgr/exec_ctx.c +27 -94
- data/src/core/lib/iomgr/exec_ctx.h +19 -22
- data/src/core/lib/iomgr/executor.c +29 -8
- data/src/core/lib/iomgr/executor.h +2 -4
- data/src/core/lib/iomgr/iocp_windows.c +3 -4
- data/src/core/lib/iomgr/iomgr.c +14 -10
- data/src/core/lib/iomgr/iomgr.h +6 -2
- data/src/core/lib/iomgr/iomgr_posix.c +2 -2
- data/src/core/lib/iomgr/iomgr_uv.c +49 -0
- data/src/core/lib/iomgr/iomgr_windows.c +2 -2
- data/src/core/lib/iomgr/load_file.c +3 -3
- data/src/core/lib/iomgr/load_file.h +2 -2
- data/src/core/lib/iomgr/network_status_tracker.c +1 -1
- data/src/core/lib/iomgr/pollset_set_uv.c +62 -0
- data/src/core/lib/iomgr/pollset_set_windows.c +3 -3
- data/src/core/lib/iomgr/pollset_uv.c +142 -0
- data/src/core/lib/iomgr/pollset_uv.h +42 -0
- data/src/core/lib/iomgr/pollset_windows.c +5 -6
- data/src/core/lib/iomgr/port.h +129 -0
- data/src/core/lib/iomgr/resolve_address.h +2 -1
- data/src/core/lib/iomgr/resolve_address_posix.c +14 -13
- data/src/core/lib/iomgr/resolve_address_uv.c +233 -0
- data/src/core/lib/iomgr/resolve_address_windows.c +14 -12
- data/src/core/lib/iomgr/resource_quota.c +832 -0
- data/src/core/lib/iomgr/resource_quota.h +159 -0
- data/src/core/lib/iomgr/sockaddr.h +10 -2
- data/src/core/lib/iomgr/sockaddr_utils.c +63 -36
- data/src/core/lib/iomgr/sockaddr_utils.h +14 -14
- data/src/core/lib/iomgr/socket_mutator.c +98 -0
- data/src/core/lib/iomgr/socket_mutator.h +80 -0
- data/src/core/lib/iomgr/socket_utils.h +42 -0
- data/src/core/lib/iomgr/socket_utils_common_posix.c +28 -13
- data/src/core/lib/iomgr/socket_utils_linux.c +11 -5
- data/src/core/lib/iomgr/socket_utils_posix.c +10 -7
- data/src/core/lib/iomgr/socket_utils_posix.h +11 -4
- data/src/core/lib/iomgr/socket_utils_uv.c +49 -0
- data/src/core/lib/iomgr/socket_utils_windows.c +52 -0
- data/src/core/lib/iomgr/socket_windows.c +14 -6
- data/src/core/lib/iomgr/socket_windows.h +1 -0
- data/src/core/lib/iomgr/tcp_client.h +8 -2
- data/src/core/lib/iomgr/tcp_client_posix.c +131 -82
- data/src/core/lib/iomgr/tcp_client_posix.h +45 -0
- data/src/core/lib/iomgr/tcp_client_uv.c +190 -0
- data/src/core/lib/iomgr/tcp_client_windows.c +54 -30
- data/src/core/lib/iomgr/tcp_posix.c +135 -56
- data/src/core/lib/iomgr/tcp_posix.h +2 -2
- data/src/core/lib/iomgr/tcp_server.h +14 -6
- data/src/core/lib/iomgr/tcp_server_posix.c +154 -118
- data/src/core/lib/iomgr/tcp_server_uv.c +388 -0
- data/src/core/lib/iomgr/tcp_server_windows.c +127 -100
- data/src/core/lib/iomgr/tcp_uv.c +367 -0
- data/src/core/lib/iomgr/tcp_uv.h +59 -0
- data/src/core/lib/iomgr/tcp_windows.c +65 -48
- data/src/core/lib/iomgr/tcp_windows.h +3 -1
- data/src/core/lib/iomgr/timer.h +21 -21
- data/src/core/lib/iomgr/{timer.c → timer_generic.c} +15 -10
- data/src/core/lib/iomgr/timer_generic.h +49 -0
- data/src/core/lib/iomgr/timer_heap.c +6 -0
- data/src/core/lib/iomgr/timer_uv.c +99 -0
- data/src/core/lib/iomgr/timer_uv.h +47 -0
- data/src/core/lib/iomgr/udp_server.c +116 -98
- data/src/core/lib/iomgr/udp_server.h +5 -3
- data/src/core/lib/iomgr/unix_sockets_posix.c +14 -6
- data/src/core/lib/iomgr/unix_sockets_posix.h +6 -5
- data/src/core/lib/iomgr/unix_sockets_posix_noop.c +4 -4
- data/src/core/lib/iomgr/wakeup_fd_cv.c +118 -0
- data/src/core/lib/iomgr/wakeup_fd_cv.h +80 -0
- data/src/core/lib/iomgr/wakeup_fd_eventfd.c +3 -3
- data/src/core/lib/iomgr/wakeup_fd_nospecial.c +3 -3
- data/src/core/lib/iomgr/wakeup_fd_pipe.c +12 -6
- data/src/core/lib/iomgr/wakeup_fd_posix.c +34 -5
- data/src/core/lib/iomgr/wakeup_fd_posix.h +5 -0
- data/src/core/lib/iomgr/workqueue.h +12 -20
- data/src/core/{ext/client_config/client_config.c → lib/iomgr/workqueue_uv.c} +24 -33
- data/{include/grpc/support/slice.h → src/core/lib/iomgr/workqueue_uv.h} +4 -6
- data/src/core/lib/iomgr/workqueue_windows.c +9 -8
- data/src/core/lib/json/json.c +3 -3
- data/src/core/lib/json/json.h +11 -11
- data/src/core/lib/json/json_reader.c +9 -5
- data/src/core/lib/profiling/basic_timers.c +10 -1
- data/src/core/lib/profiling/timers.h +2 -0
- data/src/core/lib/security/context/security_context.c +13 -3
- data/src/core/lib/security/context/security_context.h +20 -0
- data/src/core/lib/security/credentials/composite/composite_credentials.c +28 -14
- data/src/core/lib/security/credentials/composite/composite_credentials.h +2 -2
- data/src/core/lib/security/credentials/credentials.c +48 -19
- data/src/core/lib/security/credentials/credentials.h +36 -19
- data/src/core/lib/security/credentials/credentials_metadata.c +11 -8
- data/src/core/lib/security/credentials/fake/fake_credentials.c +15 -11
- data/src/core/lib/security/credentials/google_default/{credentials_posix.c → credentials_generic.c} +7 -14
- data/src/core/lib/security/credentials/google_default/google_default_credentials.c +33 -21
- data/src/core/lib/security/credentials/google_default/google_default_credentials.h +14 -0
- data/src/core/lib/security/credentials/iam/iam_credentials.c +3 -2
- data/src/core/lib/security/credentials/jwt/json_token.c +1 -0
- data/src/core/lib/security/credentials/jwt/json_token.h +1 -1
- data/src/core/lib/security/credentials/jwt/jwt_credentials.c +54 -19
- data/src/core/lib/security/credentials/jwt/jwt_credentials.h +2 -1
- data/src/core/lib/security/credentials/jwt/jwt_verifier.c +129 -79
- data/src/core/lib/security/credentials/jwt/jwt_verifier.h +9 -6
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.c +63 -28
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -1
- data/src/core/lib/security/credentials/plugin/plugin_credentials.c +32 -11
- data/src/core/lib/security/credentials/ssl/ssl_credentials.c +13 -9
- data/src/core/lib/security/transport/client_auth_filter.c +33 -27
- data/src/core/lib/security/transport/secure_endpoint.c +93 -68
- data/src/core/lib/security/transport/secure_endpoint.h +2 -2
- data/src/core/lib/security/transport/security_connector.c +133 -168
- data/src/core/lib/security/transport/security_connector.h +31 -46
- data/src/core/lib/security/transport/security_handshaker.c +501 -0
- data/src/core/lib/security/transport/{handshake.h → security_handshaker.h} +10 -10
- data/src/core/lib/security/transport/server_auth_filter.c +50 -38
- data/src/core/lib/security/util/b64.c +11 -8
- data/src/core/lib/security/util/b64.h +5 -4
- data/src/core/lib/slice/percent_encoding.c +182 -0
- data/src/core/lib/slice/percent_encoding.h +78 -0
- data/src/core/lib/{support → slice}/slice.c +81 -50
- data/src/core/lib/{support → slice}/slice_buffer.c +78 -60
- data/src/core/lib/slice/slice_internal.h +49 -0
- data/src/core/lib/slice/slice_string_helpers.c +90 -0
- data/src/core/lib/{iomgr/workqueue_posix.h → slice/slice_string_helpers.h} +18 -18
- data/src/core/lib/support/backoff.c +24 -13
- data/src/core/lib/support/backoff.h +5 -2
- data/src/core/lib/support/env.h +0 -2
- data/src/core/lib/support/log.c +5 -4
- data/src/core/lib/support/log_linux.c +0 -1
- data/src/core/lib/support/log_posix.c +1 -1
- data/src/core/lib/support/mpscq.c +83 -0
- data/src/core/lib/support/mpscq.h +65 -0
- data/src/core/lib/support/string.c +58 -49
- data/src/core/lib/support/string.h +11 -8
- data/src/core/lib/support/subprocess_posix.c +5 -2
- data/src/core/lib/support/thd.c +1 -1
- data/src/core/lib/support/time.c +43 -79
- data/src/core/lib/support/time_posix.c +1 -1
- data/src/core/lib/support/tmpfile.h +0 -2
- data/src/core/lib/surface/alarm.c +4 -1
- data/src/core/lib/surface/byte_buffer.c +17 -11
- data/src/core/lib/surface/byte_buffer_reader.c +23 -15
- data/src/core/lib/surface/call.c +294 -276
- data/src/core/lib/surface/call.h +24 -9
- data/src/core/lib/surface/call_log_batch.c +5 -3
- data/src/core/lib/surface/channel.c +127 -111
- data/src/core/lib/surface/channel.h +14 -5
- data/src/core/lib/surface/channel_init.c +1 -1
- data/src/core/lib/surface/channel_init.h +10 -1
- data/src/core/lib/surface/channel_ping.c +7 -6
- data/src/core/lib/surface/completion_queue.c +154 -18
- data/src/core/lib/surface/completion_queue.h +5 -0
- data/src/core/lib/surface/init.c +40 -6
- data/src/core/lib/surface/init.h +1 -0
- data/src/core/lib/surface/init_secure.c +5 -2
- data/src/core/lib/surface/lame_client.c +28 -18
- data/src/core/lib/surface/server.c +134 -87
- data/src/core/lib/surface/server.h +8 -0
- data/src/core/lib/surface/validate_metadata.c +1 -1
- data/src/core/lib/surface/version.c +3 -1
- data/src/core/lib/transport/byte_stream.c +7 -4
- data/src/core/lib/transport/byte_stream.h +6 -10
- data/src/core/lib/transport/connectivity_state.c +21 -12
- data/src/core/lib/transport/connectivity_state.h +4 -1
- data/src/core/lib/transport/mdstr_hash_table.c +118 -0
- data/src/core/lib/transport/mdstr_hash_table.h +77 -0
- data/src/core/lib/transport/metadata.c +83 -60
- data/src/core/lib/transport/metadata.h +41 -23
- data/src/core/lib/transport/metadata_batch.c +17 -11
- data/src/core/lib/transport/metadata_batch.h +20 -6
- data/src/core/lib/transport/pid_controller.c +57 -0
- data/src/core/lib/transport/pid_controller.h +64 -0
- data/src/core/lib/transport/service_config.c +251 -0
- data/src/core/lib/transport/service_config.h +71 -0
- data/src/core/lib/transport/static_metadata.c +18 -16
- data/src/core/lib/transport/static_metadata.h +113 -107
- data/src/core/{ext/transport/chttp2 → lib}/transport/timeout_encoding.c +3 -3
- data/src/core/{ext/transport/chttp2 → lib}/transport/timeout_encoding.h +7 -7
- data/src/core/lib/transport/transport.c +84 -23
- data/src/core/lib/transport/transport.h +53 -8
- data/src/core/lib/transport/transport_impl.h +3 -0
- data/src/core/lib/transport/transport_op_string.c +92 -20
- data/src/core/lib/tsi/ssl_transport_security.c +3 -1
- data/src/core/plugin_registry/grpc_plugin_registry.c +8 -4
- data/src/ruby/ext/grpc/extconf.rb +0 -1
- data/src/ruby/ext/grpc/rb_byte_buffer.c +8 -7
- data/src/ruby/ext/grpc/rb_call.c +15 -5
- data/src/ruby/ext/grpc/rb_channel.c +1 -1
- data/src/ruby/ext/grpc/rb_compression_options.c +466 -0
- data/src/{core/ext/client_config/default_initial_connect_string.c → ruby/ext/grpc/rb_compression_options.h} +10 -5
- data/src/ruby/ext/grpc/rb_grpc.c +3 -1
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +198 -190
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +306 -294
- data/src/ruby/ext/grpc/rb_server.c +18 -12
- data/src/ruby/lib/grpc/errors.rb +154 -2
- data/src/ruby/lib/grpc/generic/active_call.rb +144 -63
- data/src/ruby/lib/grpc/generic/bidi_call.rb +18 -2
- data/src/ruby/lib/grpc/generic/client_stub.rb +7 -5
- data/src/ruby/lib/grpc/generic/rpc_desc.rb +39 -13
- data/src/ruby/lib/grpc/generic/rpc_server.rb +51 -24
- data/src/ruby/lib/grpc/generic/service.rb +3 -2
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/checker.rb +3 -1
- data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +7 -0
- data/src/ruby/pb/test/client.rb +307 -7
- data/src/ruby/pb/test/server.rb +26 -1
- data/src/ruby/spec/compression_options_spec.rb +164 -0
- data/src/ruby/spec/error_sanity_spec.rb +64 -0
- data/src/ruby/spec/generic/active_call_spec.rb +290 -12
- data/src/ruby/spec/generic/client_stub_spec.rb +91 -41
- data/src/ruby/spec/generic/rpc_desc_spec.rb +36 -16
- data/src/ruby/spec/generic/rpc_server_pool_spec.rb +22 -28
- data/src/ruby/spec/generic/rpc_server_spec.rb +6 -6
- data/src/ruby/spec/pb/health/checker_spec.rb +27 -19
- data/src/ruby/spec/spec_helper.rb +2 -0
- data/third_party/boringssl/crypto/aes/aes.c +12 -12
- data/third_party/boringssl/crypto/aes/mode_wrappers.c +6 -2
- data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +28 -13
- data/third_party/boringssl/crypto/asn1/a_gentm.c +2 -0
- data/third_party/boringssl/crypto/asn1/a_object.c +7 -3
- data/third_party/boringssl/crypto/asn1/a_strnid.c +1 -0
- data/third_party/boringssl/crypto/asn1/a_time.c +0 -11
- data/third_party/boringssl/crypto/asn1/a_type.c +0 -2
- data/third_party/boringssl/crypto/asn1/a_utctm.c +1 -30
- data/third_party/boringssl/crypto/asn1/asn1_lib.c +56 -76
- data/third_party/boringssl/crypto/asn1/asn1_locl.h +0 -10
- data/third_party/boringssl/crypto/asn1/asn1_par.c +0 -322
- data/third_party/boringssl/crypto/asn1/f_enum.c +1 -108
- data/third_party/boringssl/crypto/asn1/f_int.c +1 -106
- data/third_party/boringssl/crypto/asn1/f_string.c +1 -106
- data/third_party/boringssl/crypto/asn1/tasn_dec.c +10 -14
- data/third_party/boringssl/crypto/asn1/tasn_enc.c +17 -11
- data/third_party/boringssl/crypto/asn1/tasn_typ.c +29 -42
- data/third_party/boringssl/crypto/asn1/tasn_utl.c +1 -1
- data/third_party/boringssl/crypto/base64/base64.c +249 -285
- data/third_party/boringssl/crypto/bio/bio.c +13 -23
- data/third_party/boringssl/crypto/bio/bio_mem.c +3 -2
- data/third_party/boringssl/crypto/bio/connect.c +12 -3
- data/third_party/boringssl/crypto/bio/fd.c +22 -15
- data/third_party/boringssl/crypto/bio/file.c +2 -38
- data/third_party/boringssl/crypto/bio/hexdump.c +1 -2
- data/third_party/boringssl/crypto/bio/internal.h +3 -0
- data/third_party/boringssl/crypto/bio/pair.c +1 -1
- data/third_party/boringssl/crypto/bio/socket.c +10 -2
- data/third_party/boringssl/crypto/bio/socket_helper.c +2 -2
- data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +0 -8
- data/third_party/boringssl/crypto/bn/bn.c +38 -0
- data/third_party/boringssl/crypto/bn/cmp.c +25 -0
- data/third_party/boringssl/crypto/bn/convert.c +73 -76
- data/third_party/boringssl/crypto/bn/div.c +136 -70
- data/third_party/boringssl/crypto/bn/exponentiation.c +86 -381
- data/third_party/boringssl/crypto/bn/gcd.c +213 -296
- data/third_party/boringssl/crypto/bn/generic.c +0 -80
- data/third_party/boringssl/crypto/bn/internal.h +15 -3
- data/third_party/boringssl/crypto/bn/montgomery.c +57 -207
- data/third_party/boringssl/crypto/bn/montgomery_inv.c +160 -0
- data/third_party/boringssl/crypto/bn/mul.c +2 -1
- data/third_party/boringssl/crypto/bn/prime.c +24 -8
- data/third_party/boringssl/crypto/bn/random.c +47 -33
- data/third_party/boringssl/crypto/bn/sqrt.c +4 -5
- data/third_party/boringssl/crypto/buf/buf.c +25 -21
- data/third_party/boringssl/crypto/bytestring/ber.c +1 -0
- data/third_party/boringssl/crypto/bytestring/cbb.c +50 -22
- data/third_party/boringssl/crypto/bytestring/cbs.c +28 -4
- data/third_party/boringssl/crypto/chacha/{chacha_generic.c → chacha.c} +56 -29
- data/third_party/boringssl/crypto/cipher/aead.c +11 -22
- data/third_party/boringssl/crypto/cipher/cipher.c +2 -2
- data/third_party/boringssl/crypto/cipher/e_aes.c +53 -103
- data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +2 -8
- data/third_party/boringssl/crypto/cipher/e_des.c +3 -5
- data/third_party/boringssl/crypto/cipher/e_null.c +1 -1
- data/third_party/boringssl/crypto/cipher/e_rc2.c +1 -1
- data/third_party/boringssl/crypto/cipher/e_rc4.c +1 -1
- data/third_party/boringssl/crypto/cipher/e_ssl3.c +3 -63
- data/third_party/boringssl/crypto/cipher/e_tls.c +12 -83
- data/third_party/boringssl/crypto/cipher/internal.h +8 -10
- data/third_party/boringssl/crypto/cipher/tls_cbc.c +69 -40
- data/third_party/boringssl/crypto/conf/conf.c +2 -1
- data/third_party/boringssl/crypto/cpu-aarch64-linux.c +61 -0
- data/third_party/boringssl/crypto/cpu-arm-linux.c +360 -0
- data/third_party/boringssl/crypto/cpu-arm.c +0 -161
- data/third_party/boringssl/crypto/cpu-intel.c +5 -3
- data/third_party/boringssl/{ssl/test/scoped_types.h → crypto/cpu-ppc64le.c} +21 -9
- data/third_party/boringssl/crypto/crypto.c +29 -7
- data/third_party/boringssl/crypto/curve25519/curve25519.c +284 -242
- data/third_party/boringssl/crypto/curve25519/internal.h +64 -0
- data/third_party/boringssl/crypto/curve25519/spake25519.c +464 -0
- data/third_party/boringssl/crypto/curve25519/x25519-x86_64.c +21 -0
- data/third_party/boringssl/crypto/dh/check.c +22 -6
- data/third_party/boringssl/crypto/dh/dh.c +45 -21
- data/third_party/boringssl/crypto/dh/dh_asn1.c +96 -20
- data/third_party/boringssl/crypto/dh/params.c +30 -78
- data/third_party/boringssl/crypto/digest/digest.c +3 -3
- data/third_party/boringssl/crypto/dsa/dsa.c +59 -29
- data/third_party/boringssl/crypto/dsa/dsa_asn1.c +4 -0
- data/third_party/boringssl/crypto/ec/ec.c +84 -140
- data/third_party/boringssl/crypto/ec/ec_asn1.c +82 -52
- data/third_party/boringssl/crypto/ec/ec_key.c +15 -15
- data/third_party/boringssl/crypto/ec/ec_montgomery.c +87 -50
- data/third_party/boringssl/crypto/ec/internal.h +12 -36
- data/third_party/boringssl/crypto/ec/oct.c +11 -11
- data/third_party/boringssl/crypto/ec/p224-64.c +59 -116
- data/third_party/boringssl/crypto/ec/p256-64.c +88 -163
- data/third_party/boringssl/crypto/ec/p256-x86_64.c +46 -58
- data/third_party/boringssl/crypto/ec/simple.c +81 -201
- data/third_party/boringssl/crypto/ec/util-64.c +0 -74
- data/third_party/boringssl/crypto/ecdh/ecdh.c +7 -1
- data/third_party/boringssl/crypto/ecdsa/ecdsa.c +28 -46
- data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +1 -0
- data/third_party/boringssl/crypto/engine/engine.c +1 -1
- data/third_party/boringssl/crypto/err/err.c +3 -3
- data/third_party/boringssl/crypto/evp/evp.c +14 -59
- data/third_party/boringssl/crypto/evp/evp_asn1.c +144 -87
- data/third_party/boringssl/crypto/evp/evp_ctx.c +7 -7
- data/third_party/boringssl/crypto/evp/internal.h +4 -46
- data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +8 -157
- data/third_party/boringssl/crypto/evp/p_ec.c +1 -1
- data/third_party/boringssl/crypto/evp/p_ec_asn1.c +22 -170
- data/third_party/boringssl/crypto/evp/p_rsa.c +1 -1
- data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +10 -548
- data/third_party/boringssl/crypto/evp/print.c +520 -0
- data/third_party/boringssl/crypto/ex_data.c +4 -6
- data/third_party/boringssl/crypto/hkdf/hkdf.c +38 -17
- data/third_party/boringssl/crypto/hmac/hmac.c +6 -6
- data/third_party/boringssl/crypto/internal.h +57 -77
- data/third_party/boringssl/crypto/lhash/lhash.c +6 -10
- data/third_party/boringssl/crypto/md4/md4.c +9 -0
- data/third_party/boringssl/crypto/mem.c +19 -19
- data/third_party/boringssl/crypto/modes/cfb.c +5 -6
- data/third_party/boringssl/crypto/modes/ctr.c +10 -18
- data/third_party/boringssl/crypto/modes/gcm.c +100 -66
- data/third_party/boringssl/crypto/modes/internal.h +15 -27
- data/third_party/boringssl/crypto/modes/ofb.c +9 -22
- data/third_party/boringssl/crypto/newhope/error_correction.c +131 -0
- data/third_party/boringssl/crypto/newhope/internal.h +71 -0
- data/third_party/boringssl/crypto/newhope/newhope.c +174 -0
- data/third_party/boringssl/crypto/newhope/ntt.c +148 -0
- data/third_party/boringssl/crypto/newhope/poly.c +183 -0
- data/third_party/boringssl/crypto/newhope/precomp.c +306 -0
- data/third_party/boringssl/crypto/newhope/reduce.c +42 -0
- data/third_party/boringssl/crypto/obj/obj.c +111 -135
- data/third_party/boringssl/crypto/obj/obj_dat.h +4 -10
- data/third_party/boringssl/crypto/pem/pem_lib.c +6 -43
- data/third_party/boringssl/crypto/pem/pem_pkey.c +10 -19
- data/third_party/boringssl/crypto/pkcs8/p5_pbe.c +1 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +2 -1
- data/third_party/boringssl/crypto/pkcs8/p8_pkey.c +2 -2
- data/third_party/boringssl/crypto/pkcs8/pkcs8.c +95 -87
- data/third_party/boringssl/crypto/{test/test_util.h → poly1305/internal.h} +15 -10
- data/third_party/boringssl/crypto/poly1305/poly1305.c +8 -15
- data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +1 -0
- data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +3 -3
- data/third_party/boringssl/crypto/rand/deterministic.c +47 -0
- data/third_party/boringssl/crypto/rand/rand.c +4 -1
- data/third_party/boringssl/crypto/rand/urandom.c +5 -7
- data/third_party/boringssl/crypto/rand/windows.c +5 -8
- data/third_party/boringssl/crypto/rc4/rc4.c +24 -209
- data/third_party/boringssl/crypto/refcount_lock.c +2 -2
- data/third_party/boringssl/crypto/rsa/blinding.c +74 -232
- data/third_party/boringssl/crypto/rsa/internal.h +5 -13
- data/third_party/boringssl/crypto/rsa/padding.c +64 -63
- data/third_party/boringssl/crypto/rsa/rsa.c +50 -28
- data/third_party/boringssl/crypto/rsa/rsa_asn1.c +8 -16
- data/third_party/boringssl/crypto/rsa/rsa_impl.c +134 -122
- data/third_party/boringssl/crypto/sha/sha256.c +2 -2
- data/third_party/boringssl/crypto/sha/sha512.c +7 -7
- data/third_party/boringssl/crypto/stack/stack.c +13 -22
- data/third_party/boringssl/crypto/thread.c +21 -12
- data/third_party/boringssl/crypto/thread_none.c +6 -2
- data/third_party/boringssl/crypto/thread_pthread.c +16 -7
- data/third_party/boringssl/crypto/thread_win.c +38 -85
- data/third_party/boringssl/crypto/x509/a_sign.c +3 -3
- data/third_party/boringssl/crypto/x509/a_strex.c +1 -1
- data/third_party/boringssl/crypto/x509/a_verify.c +2 -2
- data/third_party/boringssl/crypto/{evp → x509}/algorithm.c +37 -53
- data/third_party/boringssl/crypto/x509/asn1_gen.c +1 -2
- data/third_party/boringssl/crypto/x509/by_dir.c +6 -6
- data/third_party/boringssl/crypto/x509/internal.h +66 -0
- data/third_party/boringssl/crypto/x509/rsa_pss.c +385 -0
- data/third_party/boringssl/crypto/x509/t_x509.c +10 -12
- data/third_party/boringssl/crypto/x509/x509.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_att.c +9 -3
- data/third_party/boringssl/crypto/x509/x509_lu.c +34 -44
- data/third_party/boringssl/crypto/x509/x509_obj.c +19 -2
- data/third_party/boringssl/crypto/x509/x509_r2x.c +9 -5
- data/third_party/boringssl/crypto/x509/x509_set.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_txt.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_vfy.c +63 -32
- data/third_party/boringssl/crypto/x509/x509_vpm.c +29 -18
- data/third_party/boringssl/crypto/x509/x509cset.c +2 -1
- data/third_party/boringssl/crypto/x509/x_crl.c +2 -2
- data/third_party/boringssl/crypto/x509/x_name.c +14 -17
- data/third_party/boringssl/crypto/x509/x_pubkey.c +10 -7
- data/third_party/boringssl/crypto/x509/x_x509.c +67 -6
- data/third_party/boringssl/crypto/x509v3/pcy_cache.c +2 -2
- data/third_party/boringssl/crypto/x509v3/pcy_tree.c +2 -1
- data/third_party/boringssl/crypto/x509v3/v3_conf.c +4 -3
- data/third_party/boringssl/crypto/x509v3/v3_cpols.c +5 -0
- data/third_party/boringssl/crypto/x509v3/v3_prn.c +0 -3
- data/third_party/boringssl/crypto/x509v3/v3_purp.c +2 -2
- data/third_party/boringssl/crypto/x509v3/v3_utl.c +2 -1
- data/third_party/boringssl/include/openssl/aead.h +72 -73
- data/third_party/boringssl/include/openssl/arm_arch.h +0 -6
- data/third_party/boringssl/include/openssl/asn1.h +103 -235
- data/third_party/boringssl/include/openssl/asn1_mac.h +17 -74
- data/third_party/boringssl/include/openssl/asn1t.h +1 -11
- data/third_party/boringssl/include/openssl/base.h +145 -3
- data/third_party/boringssl/include/openssl/base64.h +20 -17
- data/third_party/boringssl/include/openssl/bio.h +59 -34
- data/third_party/boringssl/include/openssl/bn.h +118 -51
- data/third_party/boringssl/include/openssl/buf.h +15 -0
- data/third_party/boringssl/include/openssl/bytestring.h +52 -4
- data/third_party/boringssl/include/openssl/chacha.h +2 -2
- data/third_party/boringssl/include/openssl/cipher.h +18 -1
- data/third_party/boringssl/include/openssl/cmac.h +11 -0
- data/third_party/boringssl/include/openssl/conf.h +13 -2
- data/third_party/boringssl/include/openssl/cpu.h +20 -23
- data/third_party/boringssl/include/openssl/crypto.h +22 -1
- data/third_party/boringssl/include/openssl/curve25519.h +96 -4
- data/third_party/boringssl/include/openssl/dh.h +71 -16
- data/third_party/boringssl/include/openssl/digest.h +38 -11
- data/third_party/boringssl/include/openssl/dsa.h +40 -4
- data/third_party/boringssl/include/openssl/ec.h +44 -18
- data/third_party/boringssl/include/openssl/ec_key.h +27 -6
- data/third_party/boringssl/include/openssl/ecdsa.h +11 -0
- data/third_party/boringssl/include/openssl/engine.h +11 -0
- data/third_party/boringssl/include/openssl/evp.h +52 -88
- data/third_party/boringssl/include/openssl/hkdf.h +24 -4
- data/third_party/boringssl/include/openssl/hmac.h +20 -6
- data/third_party/boringssl/include/openssl/md4.h +4 -0
- data/third_party/boringssl/include/openssl/mem.h +19 -0
- data/third_party/boringssl/include/openssl/newhope.h +158 -0
- data/third_party/boringssl/include/openssl/nid.h +4166 -0
- data/third_party/boringssl/include/openssl/obj.h +31 -3
- data/third_party/boringssl/include/openssl/obj_mac.h +17 -4143
- data/third_party/boringssl/include/openssl/{opensslfeatures.h → opensslconf.h} +3 -3
- data/third_party/boringssl/include/openssl/pem.h +5 -0
- data/third_party/boringssl/include/openssl/pkcs8.h +12 -0
- data/third_party/boringssl/include/openssl/rand.h +6 -0
- data/third_party/boringssl/include/openssl/rc4.h +6 -0
- data/third_party/boringssl/{crypto/dh/internal.h → include/openssl/ripemd.h} +38 -11
- data/third_party/boringssl/include/openssl/rsa.h +127 -65
- data/third_party/boringssl/include/openssl/sha.h +14 -10
- data/third_party/boringssl/include/openssl/ssl.h +561 -275
- data/third_party/boringssl/include/openssl/ssl3.h +18 -25
- data/third_party/boringssl/include/openssl/stack.h +2 -4
- data/third_party/boringssl/include/openssl/stack_macros.h +321 -353
- data/third_party/boringssl/include/openssl/thread.h +31 -13
- data/third_party/boringssl/include/openssl/time_support.h +1 -0
- data/third_party/boringssl/include/openssl/tls1.h +37 -33
- data/third_party/boringssl/include/openssl/x509.h +69 -26
- data/third_party/boringssl/include/openssl/x509_vfy.h +12 -10
- data/third_party/boringssl/include/openssl/x509v3.h +23 -2
- data/third_party/boringssl/ssl/custom_extensions.c +3 -5
- data/third_party/boringssl/ssl/d1_both.c +463 -499
- data/third_party/boringssl/ssl/d1_lib.c +38 -109
- data/third_party/boringssl/ssl/d1_pkt.c +173 -334
- data/third_party/boringssl/ssl/d1_srtp.c +20 -18
- data/third_party/boringssl/ssl/{d1_meth.c → dtls_method.c} +88 -15
- data/third_party/boringssl/ssl/dtls_record.c +27 -26
- data/third_party/boringssl/ssl/{s3_clnt.c → handshake_client.c} +816 -904
- data/third_party/boringssl/ssl/handshake_server.c +1932 -0
- data/third_party/boringssl/ssl/internal.h +712 -439
- data/third_party/boringssl/ssl/s3_both.c +445 -257
- data/third_party/boringssl/ssl/s3_enc.c +53 -36
- data/third_party/boringssl/ssl/s3_lib.c +23 -268
- data/third_party/boringssl/ssl/s3_pkt.c +168 -364
- data/third_party/boringssl/ssl/ssl_aead_ctx.c +46 -17
- data/third_party/boringssl/ssl/ssl_asn1.c +56 -26
- data/third_party/boringssl/ssl/ssl_buffer.c +16 -24
- data/third_party/boringssl/ssl/ssl_cert.c +324 -49
- data/third_party/boringssl/ssl/ssl_cipher.c +205 -150
- data/third_party/boringssl/ssl/ssl_ecdh.c +287 -51
- data/third_party/boringssl/ssl/ssl_file.c +21 -68
- data/third_party/boringssl/ssl/ssl_lib.c +881 -510
- data/third_party/boringssl/ssl/ssl_rsa.c +404 -34
- data/third_party/boringssl/ssl/ssl_session.c +324 -103
- data/third_party/boringssl/ssl/ssl_stat.c +6 -88
- data/third_party/boringssl/ssl/t1_enc.c +23 -39
- data/third_party/boringssl/ssl/t1_lib.c +1120 -622
- data/third_party/boringssl/ssl/tls13_both.c +440 -0
- data/third_party/boringssl/ssl/tls13_client.c +682 -0
- data/third_party/boringssl/ssl/tls13_enc.c +391 -0
- data/third_party/boringssl/ssl/tls13_server.c +672 -0
- data/third_party/boringssl/ssl/{s3_meth.c → tls_method.c} +100 -21
- data/third_party/boringssl/ssl/tls_record.c +159 -77
- data/third_party/nanopb/pb.h +60 -28
- data/third_party/nanopb/pb_decode.c +120 -92
- data/third_party/nanopb/pb_decode.h +3 -3
- data/third_party/nanopb/pb_encode.c +73 -67
- data/third_party/nanopb/pb_encode.h +4 -4
- metadata +155 -89
- data/include/grpc/impl/codegen/byte_buffer.h +0 -122
- data/include/grpc/impl/codegen/log.h +0 -118
- data/include/grpc/impl/codegen/time.h +0 -130
- data/src/core/ext/client_config/client_channel.c +0 -593
- data/src/core/ext/client_config/subchannel_call_holder.c +0 -272
- data/src/core/ext/client_config/subchannel_call_holder.h +0 -99
- data/src/core/lib/iomgr/ev_poll_and_epoll_posix.c +0 -2046
- data/src/core/lib/iomgr/workqueue_posix.c +0 -151
- data/src/core/lib/security/transport/handshake.c +0 -368
- data/third_party/boringssl/crypto/asn1/a_bytes.c +0 -308
- data/third_party/boringssl/crypto/asn1/bio_asn1.c +0 -477
- data/third_party/boringssl/crypto/asn1/bio_ndef.c +0 -251
- data/third_party/boringssl/crypto/asn1/t_pkey.c +0 -110
- data/third_party/boringssl/crypto/asn1/tasn_prn.c +0 -596
- data/third_party/boringssl/crypto/chacha/chacha_vec.c +0 -328
- data/third_party/boringssl/crypto/directory.h +0 -66
- data/third_party/boringssl/crypto/directory_posix.c +0 -108
- data/third_party/boringssl/crypto/directory_win.c +0 -144
- data/third_party/boringssl/crypto/test/scoped_types.h +0 -140
- data/third_party/boringssl/include/openssl/pqueue.h +0 -146
- data/third_party/boringssl/ssl/d1_clnt.c +0 -561
- data/third_party/boringssl/ssl/d1_srvr.c +0 -476
- data/third_party/boringssl/ssl/pqueue/pqueue.c +0 -197
- data/third_party/boringssl/ssl/s3_srvr.c +0 -2272
- data/third_party/boringssl/ssl/test/async_bio.h +0 -45
- data/third_party/boringssl/ssl/test/packeted_bio.h +0 -44
- data/third_party/boringssl/ssl/test/test_config.h +0 -110
@@ -35,6 +35,8 @@
|
|
35
35
|
#define GRPC_CORE_LIB_SECURITY_TRANSPORT_SECURITY_CONNECTOR_H
|
36
36
|
|
37
37
|
#include <grpc/grpc_security.h>
|
38
|
+
|
39
|
+
#include "src/core/lib/channel/handshaker.h"
|
38
40
|
#include "src/core/lib/iomgr/endpoint.h"
|
39
41
|
#include "src/core/lib/iomgr/tcp_server.h"
|
40
42
|
#include "src/core/lib/tsi/transport_security_interface.h"
|
@@ -57,21 +59,11 @@ typedef struct grpc_security_connector grpc_security_connector;
|
|
57
59
|
|
58
60
|
#define GRPC_SECURITY_CONNECTOR_ARG "grpc.security_connector"
|
59
61
|
|
60
|
-
typedef void (*grpc_security_peer_check_cb)(grpc_exec_ctx *exec_ctx,
|
61
|
-
void *user_data,
|
62
|
-
grpc_security_status status,
|
63
|
-
grpc_auth_context *auth_context);
|
64
|
-
|
65
|
-
/* Ownership of the secure_endpoint is transfered. */
|
66
|
-
typedef void (*grpc_security_handshake_done_cb)(
|
67
|
-
grpc_exec_ctx *exec_ctx, void *user_data, grpc_security_status status,
|
68
|
-
grpc_endpoint *secure_endpoint, grpc_auth_context *auth_context);
|
69
|
-
|
70
62
|
typedef struct {
|
71
|
-
void (*destroy)(grpc_security_connector *sc);
|
63
|
+
void (*destroy)(grpc_exec_ctx *exec_ctx, grpc_security_connector *sc);
|
72
64
|
void (*check_peer)(grpc_exec_ctx *exec_ctx, grpc_security_connector *sc,
|
73
|
-
tsi_peer peer,
|
74
|
-
|
65
|
+
tsi_peer peer, grpc_auth_context **auth_context,
|
66
|
+
grpc_closure *on_peer_checked);
|
75
67
|
} grpc_security_connector_vtable;
|
76
68
|
|
77
69
|
typedef struct grpc_security_connector_handshake_list {
|
@@ -89,29 +81,32 @@ struct grpc_security_connector {
|
|
89
81
|
#ifdef GRPC_SECURITY_CONNECTOR_REFCOUNT_DEBUG
|
90
82
|
#define GRPC_SECURITY_CONNECTOR_REF(p, r) \
|
91
83
|
grpc_security_connector_ref((p), __FILE__, __LINE__, (r))
|
92
|
-
#define GRPC_SECURITY_CONNECTOR_UNREF(p, r) \
|
93
|
-
grpc_security_connector_unref((p), __FILE__, __LINE__, (r))
|
84
|
+
#define GRPC_SECURITY_CONNECTOR_UNREF(exec_ctx, p, r) \
|
85
|
+
grpc_security_connector_unref((exec_ctx), (p), __FILE__, __LINE__, (r))
|
94
86
|
grpc_security_connector *grpc_security_connector_ref(
|
95
87
|
grpc_security_connector *policy, const char *file, int line,
|
96
88
|
const char *reason);
|
97
|
-
void grpc_security_connector_unref(
|
89
|
+
void grpc_security_connector_unref(grpc_exec_ctx *exec_ctx,
|
90
|
+
grpc_security_connector *policy,
|
98
91
|
const char *file, int line,
|
99
92
|
const char *reason);
|
100
93
|
#else
|
101
94
|
#define GRPC_SECURITY_CONNECTOR_REF(p, r) grpc_security_connector_ref((p))
|
102
|
-
#define GRPC_SECURITY_CONNECTOR_UNREF(p, r)
|
95
|
+
#define GRPC_SECURITY_CONNECTOR_UNREF(exec_ctx, p, r) \
|
96
|
+
grpc_security_connector_unref((exec_ctx), (p))
|
103
97
|
grpc_security_connector *grpc_security_connector_ref(
|
104
98
|
grpc_security_connector *policy);
|
105
|
-
void grpc_security_connector_unref(
|
99
|
+
void grpc_security_connector_unref(grpc_exec_ctx *exec_ctx,
|
100
|
+
grpc_security_connector *policy);
|
106
101
|
#endif
|
107
102
|
|
108
103
|
/* Check the peer. Callee takes ownership of the peer object.
|
109
|
-
|
104
|
+
When done, sets *auth_context and invokes on_peer_checked. */
|
110
105
|
void grpc_security_connector_check_peer(grpc_exec_ctx *exec_ctx,
|
111
106
|
grpc_security_connector *sc,
|
112
107
|
tsi_peer peer,
|
113
|
-
|
114
|
-
|
108
|
+
grpc_auth_context **auth_context,
|
109
|
+
grpc_closure *on_peer_checked);
|
115
110
|
|
116
111
|
/* Util to encapsulate the connector in a channel arg. */
|
117
112
|
grpc_arg grpc_security_connector_to_arg(grpc_security_connector *sc);
|
@@ -141,10 +136,9 @@ struct grpc_channel_security_connector {
|
|
141
136
|
grpc_channel_security_connector *sc, const char *host,
|
142
137
|
grpc_auth_context *auth_context,
|
143
138
|
grpc_security_call_host_check_cb cb, void *user_data);
|
144
|
-
void (*
|
145
|
-
|
146
|
-
|
147
|
-
grpc_security_handshake_done_cb cb, void *user_data);
|
139
|
+
void (*add_handshakers)(grpc_exec_ctx *exec_ctx,
|
140
|
+
grpc_channel_security_connector *sc,
|
141
|
+
grpc_handshake_manager *handshake_mgr);
|
148
142
|
};
|
149
143
|
|
150
144
|
/* Checks that the host that will be set for a call is acceptable. */
|
@@ -153,11 +147,10 @@ void grpc_channel_security_connector_check_call_host(
|
|
153
147
|
const char *host, grpc_auth_context *auth_context,
|
154
148
|
grpc_security_call_host_check_cb cb, void *user_data);
|
155
149
|
|
156
|
-
/*
|
157
|
-
void
|
150
|
+
/* Registers handshakers with \a handshake_mgr. */
|
151
|
+
void grpc_channel_security_connector_add_handshakers(
|
158
152
|
grpc_exec_ctx *exec_ctx, grpc_channel_security_connector *connector,
|
159
|
-
|
160
|
-
grpc_security_handshake_done_cb cb, void *user_data);
|
153
|
+
grpc_handshake_manager *handshake_mgr);
|
161
154
|
|
162
155
|
/* --- server_security_connector object. ---
|
163
156
|
|
@@ -168,23 +161,14 @@ typedef struct grpc_server_security_connector grpc_server_security_connector;
|
|
168
161
|
|
169
162
|
struct grpc_server_security_connector {
|
170
163
|
grpc_security_connector base;
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
void (*do_handshake)(grpc_exec_ctx *exec_ctx,
|
175
|
-
grpc_server_security_connector *sc,
|
176
|
-
grpc_tcp_server_acceptor *acceptor,
|
177
|
-
grpc_endpoint *nonsecure_endpoint, gpr_timespec deadline,
|
178
|
-
grpc_security_handshake_done_cb cb, void *user_data);
|
164
|
+
void (*add_handshakers)(grpc_exec_ctx *exec_ctx,
|
165
|
+
grpc_server_security_connector *sc,
|
166
|
+
grpc_handshake_manager *handshake_mgr);
|
179
167
|
};
|
180
168
|
|
181
|
-
void
|
169
|
+
void grpc_server_security_connector_add_handshakers(
|
182
170
|
grpc_exec_ctx *exec_ctx, grpc_server_security_connector *sc,
|
183
|
-
|
184
|
-
gpr_timespec deadline, grpc_security_handshake_done_cb cb, void *user_data);
|
185
|
-
|
186
|
-
void grpc_server_security_connector_shutdown(
|
187
|
-
grpc_exec_ctx *exec_ctx, grpc_server_security_connector *connector);
|
171
|
+
grpc_handshake_manager *handshake_mgr);
|
188
172
|
|
189
173
|
/* --- Creation security connectors. --- */
|
190
174
|
|
@@ -222,7 +206,7 @@ typedef struct {
|
|
222
206
|
specific error code otherwise.
|
223
207
|
*/
|
224
208
|
grpc_security_status grpc_ssl_channel_security_connector_create(
|
225
|
-
grpc_call_credentials *request_metadata_creds,
|
209
|
+
grpc_exec_ctx *exec_ctx, grpc_call_credentials *request_metadata_creds,
|
226
210
|
const grpc_ssl_config *config, const char *target_name,
|
227
211
|
const char *overridden_target_name, grpc_channel_security_connector **sc);
|
228
212
|
|
@@ -230,7 +214,7 @@ grpc_security_status grpc_ssl_channel_security_connector_create(
|
|
230
214
|
size_t grpc_get_default_ssl_roots(const unsigned char **pem_root_certs);
|
231
215
|
|
232
216
|
/* Exposed for TESTING ONLY!. */
|
233
|
-
|
217
|
+
grpc_slice grpc_get_default_ssl_roots_for_testing(void);
|
234
218
|
|
235
219
|
/* Config for ssl servers. */
|
236
220
|
typedef struct {
|
@@ -251,7 +235,8 @@ typedef struct {
|
|
251
235
|
specific error code otherwise.
|
252
236
|
*/
|
253
237
|
grpc_security_status grpc_ssl_server_security_connector_create(
|
254
|
-
const grpc_ssl_server_config *config,
|
238
|
+
grpc_exec_ctx *exec_ctx, const grpc_ssl_server_config *config,
|
239
|
+
grpc_server_security_connector **sc);
|
255
240
|
|
256
241
|
/* Util. */
|
257
242
|
const tsi_peer_property *tsi_peer_get_property_by_name(const tsi_peer *peer,
|
@@ -0,0 +1,501 @@
|
|
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/lib/security/transport/security_handshaker.h"
|
35
|
+
|
36
|
+
#include <stdbool.h>
|
37
|
+
#include <string.h>
|
38
|
+
|
39
|
+
#include <grpc/slice_buffer.h>
|
40
|
+
#include <grpc/support/alloc.h>
|
41
|
+
#include <grpc/support/log.h>
|
42
|
+
|
43
|
+
#include "src/core/lib/channel/channel_args.h"
|
44
|
+
#include "src/core/lib/channel/handshaker.h"
|
45
|
+
#include "src/core/lib/channel/handshaker_registry.h"
|
46
|
+
#include "src/core/lib/security/context/security_context.h"
|
47
|
+
#include "src/core/lib/security/transport/secure_endpoint.h"
|
48
|
+
#include "src/core/lib/security/transport/tsi_error.h"
|
49
|
+
#include "src/core/lib/slice/slice_internal.h"
|
50
|
+
|
51
|
+
#define GRPC_INITIAL_HANDSHAKE_BUFFER_SIZE 256
|
52
|
+
|
53
|
+
typedef struct {
|
54
|
+
grpc_handshaker base;
|
55
|
+
|
56
|
+
// State set at creation time.
|
57
|
+
tsi_handshaker *handshaker;
|
58
|
+
grpc_security_connector *connector;
|
59
|
+
|
60
|
+
gpr_mu mu;
|
61
|
+
gpr_refcount refs;
|
62
|
+
|
63
|
+
bool shutdown;
|
64
|
+
// Endpoint and read buffer to destroy after a shutdown.
|
65
|
+
grpc_endpoint *endpoint_to_destroy;
|
66
|
+
grpc_slice_buffer *read_buffer_to_destroy;
|
67
|
+
|
68
|
+
// State saved while performing the handshake.
|
69
|
+
grpc_handshaker_args *args;
|
70
|
+
grpc_closure *on_handshake_done;
|
71
|
+
|
72
|
+
unsigned char *handshake_buffer;
|
73
|
+
size_t handshake_buffer_size;
|
74
|
+
grpc_slice_buffer left_overs;
|
75
|
+
grpc_slice_buffer outgoing;
|
76
|
+
grpc_closure on_handshake_data_sent_to_peer;
|
77
|
+
grpc_closure on_handshake_data_received_from_peer;
|
78
|
+
grpc_closure on_peer_checked;
|
79
|
+
grpc_auth_context *auth_context;
|
80
|
+
} security_handshaker;
|
81
|
+
|
82
|
+
static void security_handshaker_unref(grpc_exec_ctx *exec_ctx,
|
83
|
+
security_handshaker *h) {
|
84
|
+
if (gpr_unref(&h->refs)) {
|
85
|
+
gpr_mu_destroy(&h->mu);
|
86
|
+
tsi_handshaker_destroy(h->handshaker);
|
87
|
+
if (h->endpoint_to_destroy != NULL) {
|
88
|
+
grpc_endpoint_destroy(exec_ctx, h->endpoint_to_destroy);
|
89
|
+
}
|
90
|
+
if (h->read_buffer_to_destroy != NULL) {
|
91
|
+
grpc_slice_buffer_destroy_internal(exec_ctx, h->read_buffer_to_destroy);
|
92
|
+
gpr_free(h->read_buffer_to_destroy);
|
93
|
+
}
|
94
|
+
gpr_free(h->handshake_buffer);
|
95
|
+
grpc_slice_buffer_destroy_internal(exec_ctx, &h->left_overs);
|
96
|
+
grpc_slice_buffer_destroy_internal(exec_ctx, &h->outgoing);
|
97
|
+
GRPC_AUTH_CONTEXT_UNREF(h->auth_context, "handshake");
|
98
|
+
GRPC_SECURITY_CONNECTOR_UNREF(exec_ctx, h->connector, "handshake");
|
99
|
+
gpr_free(h);
|
100
|
+
}
|
101
|
+
}
|
102
|
+
|
103
|
+
// Set args fields to NULL, saving the endpoint and read buffer for
|
104
|
+
// later destruction.
|
105
|
+
static void cleanup_args_for_failure_locked(grpc_exec_ctx *exec_ctx,
|
106
|
+
security_handshaker *h) {
|
107
|
+
h->endpoint_to_destroy = h->args->endpoint;
|
108
|
+
h->args->endpoint = NULL;
|
109
|
+
h->read_buffer_to_destroy = h->args->read_buffer;
|
110
|
+
h->args->read_buffer = NULL;
|
111
|
+
grpc_channel_args_destroy(exec_ctx, h->args->args);
|
112
|
+
h->args->args = NULL;
|
113
|
+
}
|
114
|
+
|
115
|
+
// If the handshake failed or we're shutting down, clean up and invoke the
|
116
|
+
// callback with the error.
|
117
|
+
static void security_handshake_failed_locked(grpc_exec_ctx *exec_ctx,
|
118
|
+
security_handshaker *h,
|
119
|
+
grpc_error *error) {
|
120
|
+
if (error == GRPC_ERROR_NONE) {
|
121
|
+
// If we were shut down after the handshake succeeded but before an
|
122
|
+
// endpoint callback was invoked, we need to generate our own error.
|
123
|
+
error = GRPC_ERROR_CREATE("Handshaker shutdown");
|
124
|
+
}
|
125
|
+
const char *msg = grpc_error_string(error);
|
126
|
+
gpr_log(GPR_DEBUG, "Security handshake failed: %s", msg);
|
127
|
+
grpc_error_free_string(msg);
|
128
|
+
if (!h->shutdown) {
|
129
|
+
// TODO(ctiller): It is currently necessary to shutdown endpoints
|
130
|
+
// before destroying them, even if we know that there are no
|
131
|
+
// pending read/write callbacks. This should be fixed, at which
|
132
|
+
// point this can be removed.
|
133
|
+
grpc_endpoint_shutdown(exec_ctx, h->args->endpoint);
|
134
|
+
// Not shutting down, so the write failed. Clean up before
|
135
|
+
// invoking the callback.
|
136
|
+
cleanup_args_for_failure_locked(exec_ctx, h);
|
137
|
+
// Set shutdown to true so that subsequent calls to
|
138
|
+
// security_handshaker_shutdown() do nothing.
|
139
|
+
h->shutdown = true;
|
140
|
+
}
|
141
|
+
// Invoke callback.
|
142
|
+
grpc_closure_sched(exec_ctx, h->on_handshake_done, error);
|
143
|
+
}
|
144
|
+
|
145
|
+
static void on_peer_checked(grpc_exec_ctx *exec_ctx, void *arg,
|
146
|
+
grpc_error *error) {
|
147
|
+
security_handshaker *h = arg;
|
148
|
+
gpr_mu_lock(&h->mu);
|
149
|
+
if (error != GRPC_ERROR_NONE || h->shutdown) {
|
150
|
+
security_handshake_failed_locked(exec_ctx, h, GRPC_ERROR_REF(error));
|
151
|
+
goto done;
|
152
|
+
}
|
153
|
+
// Get frame protector.
|
154
|
+
tsi_frame_protector *protector;
|
155
|
+
tsi_result result =
|
156
|
+
tsi_handshaker_create_frame_protector(h->handshaker, NULL, &protector);
|
157
|
+
if (result != TSI_OK) {
|
158
|
+
error = grpc_set_tsi_error_result(
|
159
|
+
GRPC_ERROR_CREATE("Frame protector creation failed"), result);
|
160
|
+
security_handshake_failed_locked(exec_ctx, h, error);
|
161
|
+
goto done;
|
162
|
+
}
|
163
|
+
// Success.
|
164
|
+
// Create secure endpoint.
|
165
|
+
h->args->endpoint = grpc_secure_endpoint_create(
|
166
|
+
protector, h->args->endpoint, h->left_overs.slices, h->left_overs.count);
|
167
|
+
h->left_overs.count = 0;
|
168
|
+
h->left_overs.length = 0;
|
169
|
+
// Clear out the read buffer before it gets passed to the transport,
|
170
|
+
// since any excess bytes were already copied to h->left_overs.
|
171
|
+
grpc_slice_buffer_reset_and_unref_internal(exec_ctx, h->args->read_buffer);
|
172
|
+
// Add auth context to channel args.
|
173
|
+
grpc_arg auth_context_arg = grpc_auth_context_to_arg(h->auth_context);
|
174
|
+
grpc_channel_args *tmp_args = h->args->args;
|
175
|
+
h->args->args =
|
176
|
+
grpc_channel_args_copy_and_add(tmp_args, &auth_context_arg, 1);
|
177
|
+
grpc_channel_args_destroy(exec_ctx, tmp_args);
|
178
|
+
// Invoke callback.
|
179
|
+
grpc_closure_sched(exec_ctx, h->on_handshake_done, GRPC_ERROR_NONE);
|
180
|
+
// Set shutdown to true so that subsequent calls to
|
181
|
+
// security_handshaker_shutdown() do nothing.
|
182
|
+
h->shutdown = true;
|
183
|
+
done:
|
184
|
+
gpr_mu_unlock(&h->mu);
|
185
|
+
security_handshaker_unref(exec_ctx, h);
|
186
|
+
}
|
187
|
+
|
188
|
+
static grpc_error *check_peer_locked(grpc_exec_ctx *exec_ctx,
|
189
|
+
security_handshaker *h) {
|
190
|
+
tsi_peer peer;
|
191
|
+
tsi_result result = tsi_handshaker_extract_peer(h->handshaker, &peer);
|
192
|
+
if (result != TSI_OK) {
|
193
|
+
return grpc_set_tsi_error_result(
|
194
|
+
GRPC_ERROR_CREATE("Peer extraction failed"), result);
|
195
|
+
}
|
196
|
+
grpc_security_connector_check_peer(exec_ctx, h->connector, peer,
|
197
|
+
&h->auth_context, &h->on_peer_checked);
|
198
|
+
return GRPC_ERROR_NONE;
|
199
|
+
}
|
200
|
+
|
201
|
+
static grpc_error *send_handshake_bytes_to_peer_locked(grpc_exec_ctx *exec_ctx,
|
202
|
+
security_handshaker *h) {
|
203
|
+
// Get data to send.
|
204
|
+
tsi_result result = TSI_OK;
|
205
|
+
size_t offset = 0;
|
206
|
+
do {
|
207
|
+
size_t to_send_size = h->handshake_buffer_size - offset;
|
208
|
+
result = tsi_handshaker_get_bytes_to_send_to_peer(
|
209
|
+
h->handshaker, h->handshake_buffer + offset, &to_send_size);
|
210
|
+
offset += to_send_size;
|
211
|
+
if (result == TSI_INCOMPLETE_DATA) {
|
212
|
+
h->handshake_buffer_size *= 2;
|
213
|
+
h->handshake_buffer =
|
214
|
+
gpr_realloc(h->handshake_buffer, h->handshake_buffer_size);
|
215
|
+
}
|
216
|
+
} while (result == TSI_INCOMPLETE_DATA);
|
217
|
+
if (result != TSI_OK) {
|
218
|
+
return grpc_set_tsi_error_result(GRPC_ERROR_CREATE("Handshake failed"),
|
219
|
+
result);
|
220
|
+
}
|
221
|
+
// Send data.
|
222
|
+
grpc_slice to_send =
|
223
|
+
grpc_slice_from_copied_buffer((const char *)h->handshake_buffer, offset);
|
224
|
+
grpc_slice_buffer_reset_and_unref_internal(exec_ctx, &h->outgoing);
|
225
|
+
grpc_slice_buffer_add(&h->outgoing, to_send);
|
226
|
+
grpc_endpoint_write(exec_ctx, h->args->endpoint, &h->outgoing,
|
227
|
+
&h->on_handshake_data_sent_to_peer);
|
228
|
+
return GRPC_ERROR_NONE;
|
229
|
+
}
|
230
|
+
|
231
|
+
static void on_handshake_data_received_from_peer(grpc_exec_ctx *exec_ctx,
|
232
|
+
void *arg, grpc_error *error) {
|
233
|
+
security_handshaker *h = arg;
|
234
|
+
gpr_mu_lock(&h->mu);
|
235
|
+
if (error != GRPC_ERROR_NONE || h->shutdown) {
|
236
|
+
security_handshake_failed_locked(
|
237
|
+
exec_ctx, h,
|
238
|
+
GRPC_ERROR_CREATE_REFERENCING("Handshake read failed", &error, 1));
|
239
|
+
gpr_mu_unlock(&h->mu);
|
240
|
+
security_handshaker_unref(exec_ctx, h);
|
241
|
+
return;
|
242
|
+
}
|
243
|
+
// Process received data.
|
244
|
+
tsi_result result = TSI_OK;
|
245
|
+
size_t consumed_slice_size = 0;
|
246
|
+
size_t i;
|
247
|
+
for (i = 0; i < h->args->read_buffer->count; i++) {
|
248
|
+
consumed_slice_size = GRPC_SLICE_LENGTH(h->args->read_buffer->slices[i]);
|
249
|
+
result = tsi_handshaker_process_bytes_from_peer(
|
250
|
+
h->handshaker, GRPC_SLICE_START_PTR(h->args->read_buffer->slices[i]),
|
251
|
+
&consumed_slice_size);
|
252
|
+
if (!tsi_handshaker_is_in_progress(h->handshaker)) break;
|
253
|
+
}
|
254
|
+
if (tsi_handshaker_is_in_progress(h->handshaker)) {
|
255
|
+
/* We may need more data. */
|
256
|
+
if (result == TSI_INCOMPLETE_DATA) {
|
257
|
+
grpc_endpoint_read(exec_ctx, h->args->endpoint, h->args->read_buffer,
|
258
|
+
&h->on_handshake_data_received_from_peer);
|
259
|
+
goto done;
|
260
|
+
} else {
|
261
|
+
error = send_handshake_bytes_to_peer_locked(exec_ctx, h);
|
262
|
+
if (error != GRPC_ERROR_NONE) {
|
263
|
+
security_handshake_failed_locked(exec_ctx, h, error);
|
264
|
+
gpr_mu_unlock(&h->mu);
|
265
|
+
security_handshaker_unref(exec_ctx, h);
|
266
|
+
return;
|
267
|
+
}
|
268
|
+
goto done;
|
269
|
+
}
|
270
|
+
}
|
271
|
+
if (result != TSI_OK) {
|
272
|
+
security_handshake_failed_locked(
|
273
|
+
exec_ctx, h, grpc_set_tsi_error_result(
|
274
|
+
GRPC_ERROR_CREATE("Handshake failed"), result));
|
275
|
+
gpr_mu_unlock(&h->mu);
|
276
|
+
security_handshaker_unref(exec_ctx, h);
|
277
|
+
return;
|
278
|
+
}
|
279
|
+
/* Handshake is done and successful this point. */
|
280
|
+
bool has_left_overs_in_current_slice =
|
281
|
+
(consumed_slice_size <
|
282
|
+
GRPC_SLICE_LENGTH(h->args->read_buffer->slices[i]));
|
283
|
+
size_t num_left_overs = (has_left_overs_in_current_slice ? 1 : 0) +
|
284
|
+
h->args->read_buffer->count - i - 1;
|
285
|
+
if (num_left_overs > 0) {
|
286
|
+
/* Put the leftovers in our buffer (ownership transfered). */
|
287
|
+
if (has_left_overs_in_current_slice) {
|
288
|
+
grpc_slice_buffer_add(
|
289
|
+
&h->left_overs,
|
290
|
+
grpc_slice_split_tail(&h->args->read_buffer->slices[i],
|
291
|
+
consumed_slice_size));
|
292
|
+
/* split_tail above increments refcount. */
|
293
|
+
grpc_slice_unref_internal(exec_ctx, h->args->read_buffer->slices[i]);
|
294
|
+
}
|
295
|
+
grpc_slice_buffer_addn(
|
296
|
+
&h->left_overs, &h->args->read_buffer->slices[i + 1],
|
297
|
+
num_left_overs - (size_t)has_left_overs_in_current_slice);
|
298
|
+
}
|
299
|
+
// Check peer.
|
300
|
+
error = check_peer_locked(exec_ctx, h);
|
301
|
+
if (error != GRPC_ERROR_NONE) {
|
302
|
+
security_handshake_failed_locked(exec_ctx, h, error);
|
303
|
+
gpr_mu_unlock(&h->mu);
|
304
|
+
security_handshaker_unref(exec_ctx, h);
|
305
|
+
return;
|
306
|
+
}
|
307
|
+
done:
|
308
|
+
gpr_mu_unlock(&h->mu);
|
309
|
+
}
|
310
|
+
|
311
|
+
static void on_handshake_data_sent_to_peer(grpc_exec_ctx *exec_ctx, void *arg,
|
312
|
+
grpc_error *error) {
|
313
|
+
security_handshaker *h = arg;
|
314
|
+
gpr_mu_lock(&h->mu);
|
315
|
+
if (error != GRPC_ERROR_NONE || h->shutdown) {
|
316
|
+
security_handshake_failed_locked(
|
317
|
+
exec_ctx, h,
|
318
|
+
GRPC_ERROR_CREATE_REFERENCING("Handshake write failed", &error, 1));
|
319
|
+
gpr_mu_unlock(&h->mu);
|
320
|
+
security_handshaker_unref(exec_ctx, h);
|
321
|
+
return;
|
322
|
+
}
|
323
|
+
/* We may be done. */
|
324
|
+
if (tsi_handshaker_is_in_progress(h->handshaker)) {
|
325
|
+
grpc_endpoint_read(exec_ctx, h->args->endpoint, h->args->read_buffer,
|
326
|
+
&h->on_handshake_data_received_from_peer);
|
327
|
+
} else {
|
328
|
+
error = check_peer_locked(exec_ctx, h);
|
329
|
+
if (error != GRPC_ERROR_NONE) {
|
330
|
+
security_handshake_failed_locked(exec_ctx, h, error);
|
331
|
+
gpr_mu_unlock(&h->mu);
|
332
|
+
security_handshaker_unref(exec_ctx, h);
|
333
|
+
return;
|
334
|
+
}
|
335
|
+
}
|
336
|
+
gpr_mu_unlock(&h->mu);
|
337
|
+
}
|
338
|
+
|
339
|
+
//
|
340
|
+
// public handshaker API
|
341
|
+
//
|
342
|
+
|
343
|
+
static void security_handshaker_destroy(grpc_exec_ctx *exec_ctx,
|
344
|
+
grpc_handshaker *handshaker) {
|
345
|
+
security_handshaker *h = (security_handshaker *)handshaker;
|
346
|
+
security_handshaker_unref(exec_ctx, h);
|
347
|
+
}
|
348
|
+
|
349
|
+
static void security_handshaker_shutdown(grpc_exec_ctx *exec_ctx,
|
350
|
+
grpc_handshaker *handshaker) {
|
351
|
+
security_handshaker *h = (security_handshaker *)handshaker;
|
352
|
+
gpr_mu_lock(&h->mu);
|
353
|
+
if (!h->shutdown) {
|
354
|
+
h->shutdown = true;
|
355
|
+
grpc_endpoint_shutdown(exec_ctx, h->args->endpoint);
|
356
|
+
cleanup_args_for_failure_locked(exec_ctx, h);
|
357
|
+
}
|
358
|
+
gpr_mu_unlock(&h->mu);
|
359
|
+
}
|
360
|
+
|
361
|
+
static void security_handshaker_do_handshake(grpc_exec_ctx *exec_ctx,
|
362
|
+
grpc_handshaker *handshaker,
|
363
|
+
grpc_tcp_server_acceptor *acceptor,
|
364
|
+
grpc_closure *on_handshake_done,
|
365
|
+
grpc_handshaker_args *args) {
|
366
|
+
security_handshaker *h = (security_handshaker *)handshaker;
|
367
|
+
gpr_mu_lock(&h->mu);
|
368
|
+
h->args = args;
|
369
|
+
h->on_handshake_done = on_handshake_done;
|
370
|
+
gpr_ref(&h->refs);
|
371
|
+
grpc_error *error = send_handshake_bytes_to_peer_locked(exec_ctx, h);
|
372
|
+
if (error != GRPC_ERROR_NONE) {
|
373
|
+
security_handshake_failed_locked(exec_ctx, h, error);
|
374
|
+
gpr_mu_unlock(&h->mu);
|
375
|
+
security_handshaker_unref(exec_ctx, h);
|
376
|
+
return;
|
377
|
+
}
|
378
|
+
gpr_mu_unlock(&h->mu);
|
379
|
+
}
|
380
|
+
|
381
|
+
static const grpc_handshaker_vtable security_handshaker_vtable = {
|
382
|
+
security_handshaker_destroy, security_handshaker_shutdown,
|
383
|
+
security_handshaker_do_handshake};
|
384
|
+
|
385
|
+
static grpc_handshaker *security_handshaker_create(
|
386
|
+
grpc_exec_ctx *exec_ctx, tsi_handshaker *handshaker,
|
387
|
+
grpc_security_connector *connector) {
|
388
|
+
security_handshaker *h = gpr_malloc(sizeof(security_handshaker));
|
389
|
+
memset(h, 0, sizeof(security_handshaker));
|
390
|
+
grpc_handshaker_init(&security_handshaker_vtable, &h->base);
|
391
|
+
h->handshaker = handshaker;
|
392
|
+
h->connector = GRPC_SECURITY_CONNECTOR_REF(connector, "handshake");
|
393
|
+
gpr_mu_init(&h->mu);
|
394
|
+
gpr_ref_init(&h->refs, 1);
|
395
|
+
h->handshake_buffer_size = GRPC_INITIAL_HANDSHAKE_BUFFER_SIZE;
|
396
|
+
h->handshake_buffer = gpr_malloc(h->handshake_buffer_size);
|
397
|
+
grpc_closure_init(&h->on_handshake_data_sent_to_peer,
|
398
|
+
on_handshake_data_sent_to_peer, h,
|
399
|
+
grpc_schedule_on_exec_ctx);
|
400
|
+
grpc_closure_init(&h->on_handshake_data_received_from_peer,
|
401
|
+
on_handshake_data_received_from_peer, h,
|
402
|
+
grpc_schedule_on_exec_ctx);
|
403
|
+
grpc_closure_init(&h->on_peer_checked, on_peer_checked, h,
|
404
|
+
grpc_schedule_on_exec_ctx);
|
405
|
+
grpc_slice_buffer_init(&h->left_overs);
|
406
|
+
grpc_slice_buffer_init(&h->outgoing);
|
407
|
+
return &h->base;
|
408
|
+
}
|
409
|
+
|
410
|
+
//
|
411
|
+
// fail_handshaker
|
412
|
+
//
|
413
|
+
|
414
|
+
static void fail_handshaker_destroy(grpc_exec_ctx *exec_ctx,
|
415
|
+
grpc_handshaker *handshaker) {
|
416
|
+
gpr_free(handshaker);
|
417
|
+
}
|
418
|
+
|
419
|
+
static void fail_handshaker_shutdown(grpc_exec_ctx *exec_ctx,
|
420
|
+
grpc_handshaker *handshaker) {}
|
421
|
+
|
422
|
+
static void fail_handshaker_do_handshake(grpc_exec_ctx *exec_ctx,
|
423
|
+
grpc_handshaker *handshaker,
|
424
|
+
grpc_tcp_server_acceptor *acceptor,
|
425
|
+
grpc_closure *on_handshake_done,
|
426
|
+
grpc_handshaker_args *args) {
|
427
|
+
grpc_closure_sched(exec_ctx, on_handshake_done,
|
428
|
+
GRPC_ERROR_CREATE("Failed to create security handshaker"));
|
429
|
+
}
|
430
|
+
|
431
|
+
static const grpc_handshaker_vtable fail_handshaker_vtable = {
|
432
|
+
fail_handshaker_destroy, fail_handshaker_shutdown,
|
433
|
+
fail_handshaker_do_handshake};
|
434
|
+
|
435
|
+
static grpc_handshaker *fail_handshaker_create() {
|
436
|
+
grpc_handshaker *h = gpr_malloc(sizeof(*h));
|
437
|
+
grpc_handshaker_init(&fail_handshaker_vtable, h);
|
438
|
+
return h;
|
439
|
+
}
|
440
|
+
|
441
|
+
//
|
442
|
+
// handshaker factories
|
443
|
+
//
|
444
|
+
|
445
|
+
static void client_handshaker_factory_add_handshakers(
|
446
|
+
grpc_exec_ctx *exec_ctx, grpc_handshaker_factory *handshaker_factory,
|
447
|
+
const grpc_channel_args *args, grpc_handshake_manager *handshake_mgr) {
|
448
|
+
grpc_channel_security_connector *security_connector =
|
449
|
+
(grpc_channel_security_connector *)grpc_find_security_connector_in_args(
|
450
|
+
args);
|
451
|
+
grpc_channel_security_connector_add_handshakers(exec_ctx, security_connector,
|
452
|
+
handshake_mgr);
|
453
|
+
}
|
454
|
+
|
455
|
+
static void server_handshaker_factory_add_handshakers(
|
456
|
+
grpc_exec_ctx *exec_ctx, grpc_handshaker_factory *hf,
|
457
|
+
const grpc_channel_args *args, grpc_handshake_manager *handshake_mgr) {
|
458
|
+
grpc_server_security_connector *security_connector =
|
459
|
+
(grpc_server_security_connector *)grpc_find_security_connector_in_args(
|
460
|
+
args);
|
461
|
+
grpc_server_security_connector_add_handshakers(exec_ctx, security_connector,
|
462
|
+
handshake_mgr);
|
463
|
+
}
|
464
|
+
|
465
|
+
static void handshaker_factory_destroy(
|
466
|
+
grpc_exec_ctx *exec_ctx, grpc_handshaker_factory *handshaker_factory) {}
|
467
|
+
|
468
|
+
static const grpc_handshaker_factory_vtable client_handshaker_factory_vtable = {
|
469
|
+
client_handshaker_factory_add_handshakers, handshaker_factory_destroy};
|
470
|
+
|
471
|
+
static grpc_handshaker_factory client_handshaker_factory = {
|
472
|
+
&client_handshaker_factory_vtable};
|
473
|
+
|
474
|
+
static const grpc_handshaker_factory_vtable server_handshaker_factory_vtable = {
|
475
|
+
server_handshaker_factory_add_handshakers, handshaker_factory_destroy};
|
476
|
+
|
477
|
+
static grpc_handshaker_factory server_handshaker_factory = {
|
478
|
+
&server_handshaker_factory_vtable};
|
479
|
+
|
480
|
+
//
|
481
|
+
// exported functions
|
482
|
+
//
|
483
|
+
|
484
|
+
grpc_handshaker *grpc_security_handshaker_create(
|
485
|
+
grpc_exec_ctx *exec_ctx, tsi_handshaker *handshaker,
|
486
|
+
grpc_security_connector *connector) {
|
487
|
+
// If no TSI handshaker was created, return a handshaker that always fails.
|
488
|
+
// Otherwise, return a real security handshaker.
|
489
|
+
if (handshaker == NULL) {
|
490
|
+
return fail_handshaker_create();
|
491
|
+
} else {
|
492
|
+
return security_handshaker_create(exec_ctx, handshaker, connector);
|
493
|
+
}
|
494
|
+
}
|
495
|
+
|
496
|
+
void grpc_security_register_handshaker_factories() {
|
497
|
+
grpc_handshaker_factory_register(false /* at_start */, HANDSHAKER_CLIENT,
|
498
|
+
&client_handshaker_factory);
|
499
|
+
grpc_handshaker_factory_register(false /* at_start */, HANDSHAKER_SERVER,
|
500
|
+
&server_handshaker_factory);
|
501
|
+
}
|