grpc 0.13.1 → 0.14.1.pre1
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 +2098 -828
- data/include/grpc/byte_buffer.h +1 -1
- data/include/grpc/byte_buffer_reader.h +1 -20
- data/include/grpc/census.h +4 -4
- data/include/grpc/compression.h +6 -5
- data/include/grpc/grpc.h +31 -20
- data/include/grpc/grpc_security.h +17 -31
- data/include/grpc/grpc_security_constants.h +114 -0
- data/include/grpc/grpc_zookeeper.h +1 -1
- data/include/grpc/impl/codegen/alloc.h +1 -1
- data/include/grpc/impl/codegen/atm.h +1 -1
- data/include/grpc/impl/codegen/atm_gcc_atomic.h +1 -1
- data/include/grpc/impl/codegen/atm_gcc_sync.h +1 -1
- data/include/grpc/impl/codegen/atm_win32.h +1 -1
- data/include/grpc/impl/codegen/byte_buffer.h +1 -1
- data/{src/core/client_config/lb_policies/round_robin.h → include/grpc/impl/codegen/byte_buffer_reader.h} +19 -8
- data/include/grpc/impl/codegen/grpc_types.h +20 -3
- data/include/grpc/impl/codegen/log.h +9 -2
- data/include/grpc/impl/codegen/port_platform.h +102 -17
- data/include/grpc/impl/codegen/propagation_bits.h +3 -3
- data/include/grpc/impl/codegen/slice.h +3 -3
- data/include/grpc/impl/codegen/slice_buffer.h +3 -3
- data/include/grpc/impl/codegen/status.h +1 -1
- data/include/grpc/impl/codegen/sync_generic.h +1 -1
- data/include/grpc/impl/codegen/sync_posix.h +1 -1
- data/include/grpc/impl/codegen/sync_win32.h +1 -1
- data/include/grpc/impl/codegen/time.h +3 -3
- data/include/grpc/status.h +1 -1
- data/include/grpc/support/alloc.h +1 -1
- data/include/grpc/support/atm.h +1 -1
- data/include/grpc/support/atm_gcc_atomic.h +4 -4
- data/include/grpc/support/atm_gcc_sync.h +1 -1
- data/include/grpc/support/atm_win32.h +1 -1
- data/include/grpc/support/avl.h +1 -1
- data/include/grpc/support/cmdline.h +1 -1
- data/include/grpc/support/cpu.h +1 -1
- data/include/grpc/support/histogram.h +1 -1
- data/include/grpc/support/host_port.h +1 -1
- data/include/grpc/support/log.h +1 -1
- data/include/grpc/support/log_win32.h +1 -1
- data/include/grpc/support/port_platform.h +1 -1
- data/include/grpc/support/slice.h +1 -1
- data/include/grpc/support/slice_buffer.h +1 -1
- data/include/grpc/support/string_util.h +3 -1
- data/include/grpc/support/subprocess.h +2 -2
- data/include/grpc/support/sync.h +1 -1
- data/include/grpc/support/sync_generic.h +1 -1
- data/include/grpc/support/sync_posix.h +1 -1
- data/include/grpc/support/sync_win32.h +1 -1
- data/include/grpc/support/thd.h +1 -1
- data/include/grpc/support/time.h +1 -1
- data/include/grpc/support/tls.h +1 -1
- data/include/grpc/support/tls_gcc.h +45 -1
- data/include/grpc/support/tls_msvc.h +3 -3
- data/include/grpc/support/tls_pthread.h +1 -1
- data/include/grpc/support/useful.h +1 -1
- data/src/boringssl/err_data.c +258 -252
- data/src/core/{census → ext/census}/aggregation.h +3 -3
- data/src/core/{statistics → ext/census}/census_interface.h +3 -3
- data/src/core/{statistics → ext/census}/census_rpc_stats.h +4 -4
- data/src/core/{census → ext/census}/context.c +2 -2
- data/src/core/{census → ext/census}/grpc_context.c +2 -2
- data/src/core/{census → ext/census}/grpc_filter.c +30 -16
- data/src/core/{census → ext/census}/grpc_filter.h +4 -4
- data/src/core/ext/census/grpc_plugin.c +82 -0
- data/src/core/{census → ext/census}/initialize.c +1 -1
- data/src/core/{census → ext/census}/mlog.c +2 -2
- data/src/core/{census → ext/census}/mlog.h +4 -4
- data/src/core/{census → ext/census}/operation.c +0 -0
- data/src/core/{census → ext/census}/placeholders.c +0 -0
- data/src/core/{census → ext/census}/rpc_metric_id.h +3 -3
- data/src/core/{census → ext/census}/tracing.c +0 -0
- data/src/core/{surface → ext/client_config}/channel_connectivity.c +8 -21
- data/src/core/{channel → ext/client_config}/client_channel.c +80 -35
- data/src/core/{channel → ext/client_config}/client_channel.h +5 -5
- data/src/core/{client_config/subchannel_factory.c → ext/client_config/client_channel_factory.c} +14 -6
- data/src/core/ext/client_config/client_channel_factory.h +85 -0
- data/src/core/{client_config → ext/client_config}/client_config.c +4 -2
- data/src/core/{client_config → ext/client_config}/client_config.h +4 -4
- data/src/core/ext/client_config/client_config_plugin.c +95 -0
- data/src/core/{client_config → ext/client_config}/connector.c +2 -2
- data/src/core/{client_config → ext/client_config}/connector.h +7 -10
- data/src/core/{client_config → ext/client_config}/default_initial_connect_string.c +1 -1
- data/src/core/{client_config → ext/client_config}/initial_connect_string.c +1 -1
- data/src/core/{client_config → ext/client_config}/initial_connect_string.h +4 -4
- data/src/core/{client_config → ext/client_config}/lb_policy.c +12 -3
- data/src/core/{client_config → ext/client_config}/lb_policy.h +19 -6
- data/src/core/{client_config → ext/client_config}/lb_policy_factory.c +4 -3
- data/src/core/{client_config → ext/client_config}/lb_policy_factory.h +14 -9
- data/src/core/{client_config → ext/client_config}/lb_policy_registry.c +4 -9
- data/src/core/{client_config → ext/client_config}/lb_policy_registry.h +7 -6
- data/src/core/ext/client_config/parse_address.c +137 -0
- data/src/core/ext/client_config/parse_address.h +56 -0
- data/src/core/{client_config → ext/client_config}/resolver.c +1 -1
- data/src/core/{client_config → ext/client_config}/resolver.h +6 -6
- data/src/core/{client_config → ext/client_config}/resolver_factory.c +1 -1
- data/src/core/{client_config → ext/client_config}/resolver_factory.h +7 -7
- data/src/core/{client_config → ext/client_config}/resolver_registry.c +25 -11
- data/src/core/{client_config → ext/client_config}/resolver_registry.h +9 -5
- data/src/core/{client_config → ext/client_config}/subchannel.c +90 -126
- data/src/core/{client_config → ext/client_config}/subchannel.h +15 -15
- data/src/core/{channel → ext/client_config}/subchannel_call_holder.c +9 -8
- data/src/core/{channel → ext/client_config}/subchannel_call_holder.h +7 -7
- data/src/core/{client_config → ext/client_config}/subchannel_index.c +3 -2
- data/src/core/{client_config → ext/client_config}/subchannel_index.h +5 -5
- data/src/core/{client_config → ext/client_config}/uri_parser.c +69 -1
- data/src/core/{client_config → ext/client_config}/uri_parser.h +15 -3
- data/src/core/{client_config/lb_policies → ext/lb_policy/grpclb}/load_balancer_api.c +18 -9
- data/src/core/{client_config/lb_policies → ext/lb_policy/grpclb}/load_balancer_api.h +5 -5
- data/src/core/{proto → ext/lb_policy/grpclb/proto}/grpc/lb/v0/load_balancer.pb.c +1 -1
- data/src/core/{proto → ext/lb_policy/grpclb/proto}/grpc/lb/v0/load_balancer.pb.h +0 -0
- data/src/core/{client_config/lb_policies → ext/lb_policy/pick_first}/pick_first.c +95 -32
- data/src/core/{client_config/lb_policies → ext/lb_policy/round_robin}/round_robin.c +98 -34
- data/src/core/{client_config/resolvers → ext/resolver/dns/native}/dns_resolver.c +83 -39
- data/src/core/{client_config/resolvers → ext/resolver/sockaddr}/sockaddr_resolver.c +66 -169
- data/src/core/{transport/chttp2 → ext/transport/chttp2/alpn}/alpn.c +1 -1
- data/src/core/{transport/chttp2 → ext/transport/chttp2/alpn}/alpn.h +3 -3
- data/src/core/{surface → ext/transport/chttp2/client/insecure}/channel_create.c +65 -59
- data/src/core/{surface → ext/transport/chttp2/client/secure}/secure_channel_create.c +77 -69
- data/src/core/{surface → ext/transport/chttp2/server/insecure}/server_chttp2.c +8 -11
- data/src/core/{security → ext/transport/chttp2/server/secure}/server_secure_chttp2.c +14 -17
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/bin_encoder.c +28 -74
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/bin_encoder.h +5 -5
- data/src/core/ext/transport/chttp2/transport/chttp2_plugin.c +46 -0
- data/src/core/{transport → ext/transport/chttp2/transport}/chttp2_transport.c +551 -310
- data/src/core/{transport → ext/transport/chttp2/transport}/chttp2_transport.h +5 -5
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame.h +3 -3
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_data.c +30 -14
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_data.h +10 -7
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_goaway.c +2 -2
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_goaway.h +5 -5
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_ping.c +2 -2
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_ping.h +5 -5
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_rst_stream.c +9 -5
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_rst_stream.h +8 -6
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_settings.c +6 -6
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_settings.h +5 -5
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_window_update.c +11 -5
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/frame_window_update.h +8 -6
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/hpack_encoder.c +21 -12
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/hpack_encoder.h +8 -6
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/hpack_parser.c +42 -25
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/hpack_parser.h +7 -7
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/hpack_table.c +21 -11
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/hpack_table.h +4 -4
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/http2_errors.h +3 -3
- data/src/core/ext/transport/chttp2/transport/huffsyms.c +105 -0
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/huffsyms.h +3 -3
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/incoming_metadata.c +2 -2
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/incoming_metadata.h +4 -4
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/internal.h +81 -37
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/parsing.c +54 -21
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/status_conversion.c +1 -1
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/status_conversion.h +4 -4
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/stream_lists.c +10 -2
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/stream_map.c +1 -1
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/stream_map.h +3 -3
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/timeout_encoding.c +4 -4
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/timeout_encoding.h +4 -4
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/varint.c +1 -1
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/varint.h +3 -3
- data/src/core/{transport/chttp2 → ext/transport/chttp2/transport}/writing.c +30 -20
- data/src/core/{channel → lib/channel}/channel_args.c +3 -15
- data/src/core/{channel → lib/channel}/channel_args.h +11 -15
- data/src/core/{channel → lib/channel}/channel_stack.c +5 -3
- data/src/core/{channel → lib/channel}/channel_stack.h +13 -8
- data/src/core/lib/channel/channel_stack_builder.c +277 -0
- data/src/core/lib/channel/channel_stack_builder.h +161 -0
- data/src/core/{channel → lib/channel}/compress_filter.c +51 -16
- data/src/core/{channel → lib/channel}/compress_filter.h +6 -4
- data/src/core/{channel → lib/channel}/connected_channel.c +34 -24
- data/src/core/lib/channel/connected_channel.h +42 -0
- data/src/core/{channel → lib/channel}/context.h +3 -3
- data/src/core/{channel → lib/channel}/http_client_filter.c +24 -13
- data/src/core/{channel → lib/channel}/http_client_filter.h +4 -4
- data/src/core/{channel → lib/channel}/http_server_filter.c +39 -19
- data/src/core/{channel → lib/channel}/http_server_filter.h +4 -4
- data/src/core/{compression → lib/compression}/algorithm_metadata.h +4 -4
- data/src/core/{compression → lib/compression}/compression_algorithm.c +46 -9
- data/src/core/{compression → lib/compression}/message_compress.c +1 -1
- data/src/core/{compression → lib/compression}/message_compress.h +3 -3
- data/src/core/{debug → lib/debug}/trace.c +2 -2
- data/src/core/{debug → lib/debug}/trace.h +3 -3
- data/src/core/{httpcli → lib/http}/format_request.c +8 -8
- data/src/core/{httpcli → lib/http}/format_request.h +4 -4
- data/src/core/{httpcli → lib/http}/httpcli.c +24 -19
- data/src/core/{httpcli → lib/http}/httpcli.h +14 -33
- data/src/core/{httpcli → lib/http}/httpcli_security_connector.c +5 -5
- data/src/core/lib/http/parser.c +341 -0
- data/src/core/lib/http/parser.h +119 -0
- data/src/core/{iomgr → lib/iomgr}/closure.c +8 -2
- data/src/core/{iomgr → lib/iomgr}/closure.h +7 -4
- data/src/core/{iomgr → lib/iomgr}/endpoint.c +1 -1
- data/src/core/{iomgr → lib/iomgr}/endpoint.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/endpoint_pair.h +4 -4
- data/src/core/{iomgr → lib/iomgr}/endpoint_pair_posix.c +8 -7
- data/src/core/{iomgr → lib/iomgr}/endpoint_pair_windows.c +4 -4
- data/src/core/lib/iomgr/ev_poll_and_epoll_posix.c +1936 -0
- data/src/core/lib/iomgr/ev_poll_and_epoll_posix.h +41 -0
- data/src/core/lib/iomgr/ev_posix.c +164 -0
- data/src/core/lib/iomgr/ev_posix.h +158 -0
- data/src/core/{iomgr → lib/iomgr}/exec_ctx.c +78 -3
- data/src/core/{iomgr → lib/iomgr}/exec_ctx.h +25 -10
- data/src/core/{iomgr → lib/iomgr}/executor.c +3 -3
- data/src/core/{iomgr → lib/iomgr}/executor.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/iocp_windows.c +6 -6
- data/src/core/{iomgr → lib/iomgr}/iocp_windows.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/iomgr.c +13 -10
- data/src/core/{iomgr → lib/iomgr}/iomgr.h +3 -3
- data/src/core/{iomgr → lib/iomgr}/iomgr_internal.h +5 -9
- data/src/core/{iomgr → lib/iomgr}/iomgr_posix.c +6 -6
- data/src/core/{iomgr → lib/iomgr}/iomgr_posix.h +4 -4
- data/src/core/{iomgr → lib/iomgr}/iomgr_windows.c +7 -4
- data/src/core/{iomgr → lib/iomgr}/pollset.h +11 -11
- data/src/core/{iomgr → lib/iomgr}/pollset_set.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/pollset_set_windows.c +2 -2
- data/src/core/lib/iomgr/pollset_set_windows.h +39 -0
- data/src/core/{iomgr → lib/iomgr}/pollset_windows.c +7 -7
- data/src/core/{iomgr → lib/iomgr}/pollset_windows.h +8 -5
- data/src/core/{iomgr → lib/iomgr}/resolve_address.h +10 -9
- data/src/core/{iomgr → lib/iomgr}/resolve_address_posix.c +22 -22
- data/src/core/{iomgr → lib/iomgr}/resolve_address_windows.c +20 -12
- data/src/core/{iomgr → lib/iomgr}/sockaddr.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/sockaddr_posix.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/sockaddr_utils.c +9 -16
- data/src/core/{iomgr → lib/iomgr}/sockaddr_utils.h +4 -4
- data/src/core/{iomgr → lib/iomgr}/sockaddr_win32.h +6 -4
- data/src/core/{iomgr → lib/iomgr}/socket_utils_common_posix.c +29 -7
- data/src/core/{iomgr → lib/iomgr}/socket_utils_linux.c +2 -2
- data/src/core/{iomgr → lib/iomgr}/socket_utils_posix.c +1 -1
- data/src/core/{iomgr → lib/iomgr}/socket_utils_posix.h +14 -4
- data/src/core/{iomgr → lib/iomgr}/socket_windows.c +7 -5
- data/src/core/{iomgr → lib/iomgr}/socket_windows.h +6 -6
- data/src/core/{iomgr → lib/iomgr}/tcp_client.h +6 -6
- data/src/core/{iomgr → lib/iomgr}/tcp_client_posix.c +33 -18
- data/src/core/{iomgr → lib/iomgr}/tcp_client_windows.c +30 -20
- data/src/core/{iomgr → lib/iomgr}/tcp_posix.c +9 -10
- data/src/core/{iomgr → lib/iomgr}/tcp_posix.h +6 -6
- data/src/core/{iomgr → lib/iomgr}/tcp_server.h +6 -6
- data/src/core/{iomgr → lib/iomgr}/tcp_server_posix.c +24 -37
- data/src/core/{iomgr → lib/iomgr}/tcp_server_windows.c +8 -36
- data/src/core/{iomgr → lib/iomgr}/tcp_windows.c +27 -17
- data/src/core/{iomgr → lib/iomgr}/tcp_windows.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/time_averaged_stats.c +1 -1
- data/src/core/{iomgr → lib/iomgr}/time_averaged_stats.h +3 -3
- data/src/core/{iomgr → lib/iomgr}/timer.c +31 -4
- data/src/core/{iomgr → lib/iomgr}/timer.h +6 -7
- data/src/core/{iomgr → lib/iomgr}/timer_heap.c +2 -2
- data/src/core/{iomgr → lib/iomgr}/timer_heap.h +4 -4
- data/src/core/{iomgr → lib/iomgr}/udp_server.c +13 -37
- data/src/core/{iomgr → lib/iomgr}/udp_server.h +11 -10
- data/src/core/lib/iomgr/unix_sockets_posix.c +89 -0
- data/src/core/{client_config/resolvers/sockaddr_resolver.h → lib/iomgr/unix_sockets_posix.h} +15 -11
- data/src/core/lib/iomgr/unix_sockets_posix_noop.c +59 -0
- data/src/core/{iomgr → lib/iomgr}/wakeup_fd_eventfd.c +2 -2
- data/src/core/{iomgr → lib/iomgr}/wakeup_fd_nospecial.c +1 -1
- data/src/core/{iomgr → lib/iomgr}/wakeup_fd_pipe.c +8 -3
- data/src/core/{iomgr → lib/iomgr}/wakeup_fd_pipe.h +4 -4
- data/src/core/{iomgr → lib/iomgr}/wakeup_fd_posix.c +2 -2
- data/src/core/{iomgr → lib/iomgr}/wakeup_fd_posix.h +3 -3
- data/src/core/{iomgr → lib/iomgr}/workqueue.h +10 -10
- data/src/core/{iomgr → lib/iomgr}/workqueue_posix.c +5 -6
- data/src/core/{iomgr → lib/iomgr}/workqueue_posix.h +5 -5
- data/src/core/{iomgr → lib/iomgr}/workqueue_windows.c +1 -1
- data/src/core/{iomgr → lib/iomgr}/workqueue_windows.h +3 -3
- data/src/core/{json → lib/json}/json.c +1 -1
- data/src/core/{json → lib/json}/json.h +4 -4
- data/src/core/{json → lib/json}/json_common.h +3 -3
- data/src/core/{json → lib/json}/json_reader.c +16 -4
- data/src/core/{json → lib/json}/json_reader.h +4 -4
- data/src/core/{json → lib/json}/json_string.c +4 -4
- data/src/core/{json → lib/json}/json_writer.c +1 -1
- data/src/core/{json → lib/json}/json_writer.h +4 -4
- data/src/core/{profiling → lib/profiling}/basic_timers.c +3 -2
- data/src/core/{profiling → lib/profiling}/stap_timers.c +2 -2
- data/src/core/{profiling → lib/profiling}/timers.h +3 -3
- data/src/core/{security → lib/security}/auth_filters.h +4 -4
- data/src/core/{security → lib/security}/b64.c +2 -2
- data/src/core/{security → lib/security}/b64.h +4 -4
- data/src/core/{security → lib/security}/client_auth_filter.c +16 -16
- data/src/core/{security → lib/security}/credentials.c +42 -26
- data/src/core/{security → lib/security}/credentials.h +11 -10
- data/src/core/{security → lib/security}/credentials_metadata.c +1 -1
- data/src/core/{security → lib/security}/credentials_posix.c +3 -3
- data/src/core/{security → lib/security}/credentials_win32.c +3 -3
- data/src/core/{security → lib/security}/google_default_credentials.c +10 -9
- data/src/core/{security → lib/security}/handshake.c +4 -4
- data/src/core/{security → lib/security}/handshake.h +6 -6
- data/src/core/{security → lib/security}/json_token.c +4 -4
- data/src/core/{security → lib/security}/json_token.h +4 -4
- data/src/core/{security → lib/security}/jwt_verifier.c +14 -14
- data/src/core/{security → lib/security}/jwt_verifier.h +5 -5
- data/src/core/{security → lib/security}/secure_endpoint.c +9 -8
- data/src/core/{security → lib/security}/secure_endpoint.h +4 -4
- data/src/core/{security → lib/security}/security_connector.c +53 -21
- data/src/core/{security → lib/security}/security_connector.h +8 -8
- data/src/core/{security → lib/security}/security_context.c +5 -5
- data/src/core/{security → lib/security}/security_context.h +5 -5
- data/src/core/{security → lib/security}/server_auth_filter.c +9 -9
- data/src/core/{support → lib/support}/alloc.c +5 -3
- data/src/core/{support → lib/support}/avl.c +1 -1
- data/src/core/lib/support/backoff.c +76 -0
- data/src/core/lib/support/backoff.h +68 -0
- data/src/core/{support → lib/support}/block_annotate.h +3 -3
- data/src/core/{support → lib/support}/cmdline.c +1 -1
- data/src/core/{support → lib/support}/cpu_iphone.c +0 -0
- data/src/core/{support → lib/support}/cpu_linux.c +2 -2
- data/src/core/{support → lib/support}/cpu_posix.c +2 -2
- data/src/core/{support → lib/support}/cpu_windows.c +0 -0
- data/src/core/{support → lib/support}/env.h +3 -3
- data/src/core/{support → lib/support}/env_linux.c +3 -3
- data/src/core/{support → lib/support}/env_posix.c +2 -2
- data/src/core/{support → lib/support}/env_win32.c +27 -21
- data/src/core/{support → lib/support}/histogram.c +1 -1
- data/src/core/{support → lib/support}/host_port.c +1 -1
- data/src/core/{support → lib/support}/load_file.c +4 -4
- data/src/core/{support → lib/support}/load_file.h +4 -4
- data/src/core/{support → lib/support}/log.c +33 -0
- data/src/core/{support → lib/support}/log_android.c +2 -2
- data/src/core/{support → lib/support}/log_linux.c +6 -5
- data/src/core/{support → lib/support}/log_posix.c +3 -3
- data/src/core/{support → lib/support}/log_win32.c +8 -22
- data/src/core/{support → lib/support}/murmur_hash.c +1 -1
- data/src/core/{support → lib/support}/murmur_hash.h +3 -3
- data/src/core/{support → lib/support}/slice.c +0 -0
- data/src/core/{support → lib/support}/slice_buffer.c +0 -0
- data/src/core/{support → lib/support}/stack_lockfree.c +7 -7
- data/src/core/{support → lib/support}/stack_lockfree.h +3 -3
- data/src/core/{support → lib/support}/string.c +1 -1
- data/src/core/{support → lib/support}/string.h +4 -4
- data/src/core/{support → lib/support}/string_posix.c +1 -1
- data/src/core/{support/string_win32.c → lib/support/string_util_win32.c} +23 -38
- data/src/core/lib/support/string_win32.c +83 -0
- data/src/core/{support → lib/support}/string_win32.h +3 -3
- data/src/core/{support → lib/support}/subprocess_posix.c +3 -3
- data/src/core/{support → lib/support}/subprocess_windows.c +3 -3
- data/src/core/{support → lib/support}/sync.c +2 -2
- data/src/core/{support → lib/support}/sync_posix.c +3 -3
- data/src/core/{support → lib/support}/sync_win32.c +1 -1
- data/src/core/{support → lib/support}/thd.c +0 -0
- data/src/core/{support → lib/support}/thd_internal.h +3 -3
- data/src/core/{support → lib/support}/thd_posix.c +4 -3
- data/src/core/{support → lib/support}/thd_win32.c +1 -1
- data/src/core/{support → lib/support}/time.c +2 -2
- data/src/core/{support → lib/support}/time_posix.c +12 -6
- data/src/core/{support → lib/support}/time_precise.c +0 -0
- data/src/core/{support → lib/support}/time_precise.h +3 -3
- data/src/core/{support → lib/support}/time_win32.c +7 -7
- data/src/core/{support → lib/support}/tls_pthread.c +0 -0
- data/src/core/{support → lib/support}/tmpfile.h +4 -4
- data/src/core/lib/support/tmpfile_msys.c +73 -0
- data/src/core/{support → lib/support}/tmpfile_posix.c +5 -5
- data/src/core/{support → lib/support}/tmpfile_win32.c +5 -5
- data/src/core/{support → lib/support}/wrap_memcpy.c +0 -0
- data/src/core/{surface → lib/surface}/alarm.c +3 -3
- data/src/core/{surface → lib/surface}/api_trace.c +1 -1
- data/src/core/{surface → lib/surface}/api_trace.h +4 -4
- data/src/core/{surface → lib/surface}/byte_buffer.c +3 -3
- data/src/core/{surface → lib/surface}/byte_buffer_reader.c +3 -3
- data/src/core/{surface → lib/surface}/call.c +145 -73
- data/src/core/{surface → lib/surface}/call.h +14 -7
- data/src/core/{surface → lib/surface}/call_details.c +1 -1
- data/src/core/{surface → lib/surface}/call_log_batch.c +2 -2
- data/src/core/{surface → lib/surface}/call_test_only.h +3 -3
- data/src/core/{surface → lib/surface}/channel.c +33 -34
- data/src/core/{surface → lib/surface}/channel.h +9 -9
- data/src/core/lib/surface/channel_init.c +140 -0
- data/src/core/lib/surface/channel_init.h +87 -0
- data/src/core/{surface → lib/surface}/channel_ping.c +4 -4
- data/src/core/lib/surface/channel_stack_type.c +54 -0
- data/src/core/{httpcli/parser.h → lib/surface/channel_stack_type.h} +22 -28
- data/src/core/{surface → lib/surface}/completion_queue.c +15 -11
- data/src/core/{surface → lib/surface}/completion_queue.h +4 -4
- data/src/core/{surface → lib/surface}/event_string.c +2 -2
- data/src/core/{surface → lib/surface}/event_string.h +3 -3
- data/src/core/lib/surface/init.c +217 -0
- data/src/core/{surface → lib/surface}/init.h +4 -3
- data/src/core/lib/surface/init_secure.c +89 -0
- data/src/core/{surface → lib/surface}/lame_client.c +31 -19
- data/src/core/{iomgr/pollset_set_windows.h → lib/surface/lame_client.h} +7 -5
- data/src/core/{surface → lib/surface}/metadata_array.c +1 -1
- data/src/core/{surface → lib/surface}/server.c +208 -183
- data/src/core/{surface → lib/surface}/server.h +6 -11
- data/src/core/{surface → lib/surface}/surface_trace.h +5 -5
- data/src/core/{surface → lib/surface}/validate_metadata.c +1 -1
- data/src/core/{surface → lib/surface}/version.c +2 -2
- data/src/core/{transport → lib/transport}/byte_stream.c +1 -1
- data/src/core/{transport → lib/transport}/byte_stream.h +4 -4
- data/src/core/{transport → lib/transport}/connectivity_state.c +2 -2
- data/src/core/{transport → lib/transport}/connectivity_state.h +4 -4
- data/src/core/{transport → lib/transport}/metadata.c +71 -19
- data/src/core/{transport → lib/transport}/metadata.h +11 -4
- data/src/core/{transport → lib/transport}/metadata_batch.c +2 -2
- data/src/core/{transport → lib/transport}/metadata_batch.h +4 -4
- data/src/core/{transport → lib/transport}/static_metadata.c +100 -32
- data/src/core/{transport → lib/transport}/static_metadata.h +58 -58
- data/src/core/{transport → lib/transport}/transport.c +25 -5
- data/src/core/{transport → lib/transport}/transport.h +41 -16
- data/src/core/{transport → lib/transport}/transport_impl.h +8 -5
- data/src/core/{transport → lib/transport}/transport_op_string.c +2 -2
- data/src/core/{tsi → lib/tsi}/fake_transport_security.c +18 -14
- data/src/core/{tsi → lib/tsi}/fake_transport_security.h +4 -4
- data/src/core/{tsi → lib/tsi}/ssl_transport_security.c +173 -63
- data/src/core/{tsi → lib/tsi}/ssl_transport_security.h +24 -6
- data/src/core/{tsi → lib/tsi}/ssl_types.h +3 -3
- data/src/core/{tsi → lib/tsi}/transport_security.c +12 -28
- data/src/core/{tsi → lib/tsi}/transport_security.h +4 -4
- data/src/core/{tsi → lib/tsi}/transport_security_interface.h +12 -3
- data/src/core/plugin_registry/grpc_plugin_registry.c +66 -0
- data/src/ruby/ext/grpc/extconf.rb +14 -20
- data/src/ruby/ext/grpc/rb_byte_buffer.c +2 -3
- data/src/ruby/ext/grpc/rb_call.c +37 -4
- data/src/ruby/ext/grpc/rb_call_credentials.c +13 -3
- data/src/ruby/ext/grpc/rb_channel.c +2 -3
- data/src/ruby/ext/grpc/rb_channel_args.c +2 -3
- data/src/ruby/ext/grpc/rb_channel_credentials.c +31 -3
- data/src/ruby/ext/grpc/rb_completion_queue.c +2 -2
- data/src/ruby/ext/grpc/rb_event_thread.c +1 -1
- data/src/ruby/ext/grpc/rb_grpc.c +4 -2
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +8 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +14 -2
- data/src/ruby/ext/grpc/rb_server.c +2 -3
- data/src/ruby/ext/grpc/rb_server_credentials.c +16 -13
- data/src/ruby/ext/grpc/rb_signal.c +70 -0
- data/src/ruby/ext/grpc/rb_signal.h +39 -0
- data/src/ruby/lib/grpc.rb +21 -13
- data/src/ruby/lib/grpc/core/time_consts.rb +2 -2
- data/src/ruby/lib/grpc/errors.rb +2 -2
- data/src/ruby/lib/grpc/generic/active_call.rb +10 -3
- data/src/ruby/lib/grpc/generic/bidi_call.rb +2 -2
- data/src/ruby/lib/grpc/generic/client_stub.rb +10 -7
- data/src/ruby/lib/grpc/generic/rpc_desc.rb +2 -2
- data/src/ruby/lib/grpc/generic/rpc_server.rb +21 -61
- data/src/ruby/lib/grpc/generic/service.rb +5 -15
- data/src/ruby/lib/grpc/grpc.rb +3 -3
- data/src/ruby/{bin/interop/interop_server.rb → lib/grpc/signals.rb} +39 -20
- data/src/ruby/lib/grpc/version.rb +2 -2
- data/src/ruby/pb/generate_proto_ruby.sh +9 -2
- data/src/ruby/pb/grpc/health/checker.rb +1 -1
- data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services.rb +28 -0
- data/src/ruby/pb/grpc/testing/metrics.rb +28 -0
- data/src/ruby/pb/grpc/testing/metrics_services.rb +27 -0
- data/src/ruby/pb/test/client.rb +12 -23
- data/src/ruby/pb/test/server.rb +1 -1
- data/src/ruby/spec/client_server_spec.rb +1 -1
- data/src/ruby/spec/generic/client_stub_spec.rb +18 -17
- data/src/ruby/spec/generic/rpc_server_spec.rb +23 -7
- data/src/ruby/spec/generic/service_spec.rb +0 -69
- data/src/ruby/{bin/interop/interop_client.rb → spec/pb/duplicate/codegen_spec.rb} +41 -21
- data/src/ruby/spec/pb/health/checker_spec.rb +1 -1
- data/third_party/boringssl/crypto/asn1/a_bitstr.c +184 -176
- data/third_party/boringssl/crypto/asn1/a_bool.c +42 -44
- data/third_party/boringssl/crypto/asn1/a_bytes.c +236 -245
- data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +173 -192
- data/third_party/boringssl/crypto/asn1/a_dup.c +43 -35
- data/third_party/boringssl/crypto/asn1/a_enum.c +107 -109
- data/third_party/boringssl/crypto/asn1/a_gentm.c +180 -181
- data/third_party/boringssl/crypto/asn1/a_i2d_fp.c +73 -80
- data/third_party/boringssl/crypto/asn1/a_int.c +357 -353
- data/third_party/boringssl/crypto/asn1/a_mbstr.c +272 -253
- data/third_party/boringssl/crypto/asn1/a_object.c +293 -309
- data/third_party/boringssl/crypto/asn1/a_octet.c +13 -6
- data/third_party/boringssl/crypto/asn1/a_print.c +54 -52
- data/third_party/boringssl/crypto/asn1/a_strnid.c +179 -157
- data/third_party/boringssl/crypto/asn1/a_time.c +125 -129
- data/third_party/boringssl/crypto/asn1/a_type.c +79 -86
- data/third_party/boringssl/crypto/asn1/a_utctm.c +246 -255
- data/third_party/boringssl/crypto/asn1/a_utf8.c +159 -135
- data/third_party/boringssl/crypto/asn1/asn1_lib.c +361 -368
- data/third_party/boringssl/crypto/asn1/asn1_locl.h +11 -11
- data/third_party/boringssl/crypto/asn1/asn1_par.c +309 -351
- data/third_party/boringssl/crypto/asn1/asn_pack.c +30 -29
- data/third_party/boringssl/crypto/asn1/bio_asn1.c +375 -394
- data/third_party/boringssl/crypto/asn1/bio_ndef.c +146 -149
- data/third_party/boringssl/crypto/asn1/f_enum.c +128 -134
- data/third_party/boringssl/crypto/asn1/f_int.c +131 -139
- data/third_party/boringssl/crypto/asn1/f_string.c +125 -133
- data/third_party/boringssl/crypto/asn1/t_bitst.c +30 -29
- data/third_party/boringssl/crypto/asn1/t_pkey.c +45 -47
- data/third_party/boringssl/crypto/asn1/tasn_dec.c +1099 -1216
- data/third_party/boringssl/crypto/asn1/tasn_enc.c +556 -592
- data/third_party/boringssl/crypto/asn1/tasn_fre.c +175 -193
- data/third_party/boringssl/crypto/asn1/tasn_new.c +271 -288
- data/third_party/boringssl/crypto/asn1/tasn_prn.c +462 -508
- data/third_party/boringssl/crypto/asn1/tasn_typ.c +28 -21
- data/third_party/boringssl/crypto/asn1/x_bignum.c +62 -52
- data/third_party/boringssl/crypto/asn1/x_long.c +101 -86
- data/third_party/boringssl/crypto/bio/buffer.c +3 -3
- data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +8 -68
- data/third_party/boringssl/crypto/bn/bn.c +1 -1
- data/third_party/boringssl/crypto/bn/bn_asn1.c +9 -22
- data/third_party/boringssl/crypto/bn/convert.c +9 -4
- data/third_party/boringssl/crypto/bn/div.c +0 -20
- data/third_party/boringssl/crypto/bn/exponentiation.c +22 -13
- data/third_party/boringssl/crypto/bn/generic.c +6 -242
- data/third_party/boringssl/crypto/bn/internal.h +9 -70
- data/third_party/boringssl/crypto/bn/montgomery.c +1 -2
- data/third_party/boringssl/crypto/bn/mul.c +6 -26
- data/third_party/boringssl/crypto/bn/rsaz_exp.c +21 -28
- data/third_party/boringssl/crypto/bytestring/asn1_compat.c +51 -0
- data/third_party/boringssl/crypto/bytestring/ber.c +128 -87
- data/third_party/boringssl/crypto/bytestring/cbb.c +37 -3
- data/third_party/boringssl/crypto/bytestring/internal.h +39 -10
- data/third_party/boringssl/crypto/chacha/chacha_vec.c +18 -13
- data/third_party/boringssl/crypto/cipher/e_aes.c +2 -2
- data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +4 -9
- data/third_party/boringssl/crypto/cipher/tls_cbc.c +39 -10
- data/third_party/boringssl/crypto/conf/conf.c +9 -0
- data/third_party/boringssl/crypto/cpu-intel.c +1 -1
- data/third_party/boringssl/crypto/crypto.c +2 -0
- data/third_party/boringssl/crypto/curve25519/curve25519.c +125 -120
- data/third_party/boringssl/crypto/curve25519/internal.h +45 -0
- data/third_party/boringssl/crypto/curve25519/x25519-x86_64.c +225 -0
- data/third_party/boringssl/crypto/dh/check.c +32 -10
- data/third_party/boringssl/crypto/dh/dh.c +1 -1
- data/third_party/boringssl/crypto/digest/md32_common.h +0 -60
- data/third_party/boringssl/crypto/dsa/dsa.c +47 -21
- data/third_party/boringssl/crypto/dsa/dsa_asn1.c +249 -64
- data/third_party/boringssl/crypto/ec/ec.c +45 -31
- data/third_party/boringssl/crypto/ec/ec_asn1.c +315 -382
- data/third_party/boringssl/crypto/ec/ec_key.c +1 -4
- data/third_party/boringssl/crypto/ec/ec_montgomery.c +0 -9
- data/third_party/boringssl/crypto/ec/internal.h +1 -19
- data/third_party/boringssl/crypto/ec/oct.c +12 -0
- data/third_party/boringssl/crypto/ec/p224-64.c +4 -65
- data/third_party/boringssl/crypto/ec/p256-64.c +9 -71
- data/third_party/boringssl/crypto/ec/p256-x86_64-table.h +1 -6
- data/third_party/boringssl/crypto/ec/p256-x86_64.c +3 -13
- data/third_party/boringssl/crypto/ec/simple.c +0 -76
- data/third_party/boringssl/crypto/ecdsa/ecdsa.c +1 -1
- data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +10 -24
- data/third_party/boringssl/crypto/evp/evp.c +4 -3
- data/third_party/boringssl/crypto/evp/evp_asn1.c +101 -0
- data/third_party/boringssl/crypto/evp/evp_ctx.c +22 -51
- data/third_party/boringssl/crypto/evp/internal.h +28 -27
- data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +78 -249
- data/third_party/boringssl/crypto/evp/p_ec.c +19 -66
- data/third_party/boringssl/crypto/evp/p_ec_asn1.c +74 -231
- data/third_party/boringssl/crypto/evp/p_rsa.c +90 -13
- data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +49 -48
- data/third_party/boringssl/crypto/internal.h +16 -1
- data/third_party/boringssl/crypto/mem.c +2 -2
- data/third_party/boringssl/crypto/modes/ctr.c +2 -1
- data/third_party/boringssl/crypto/modes/gcm.c +5 -3
- data/third_party/boringssl/crypto/obj/obj_dat.h +6 -3
- data/third_party/boringssl/crypto/pem/pem_all.c +83 -102
- data/third_party/boringssl/crypto/pem/pem_info.c +286 -309
- data/third_party/boringssl/crypto/pem/pem_lib.c +690 -710
- data/third_party/boringssl/crypto/pem/pem_oth.c +15 -16
- data/third_party/boringssl/crypto/pem/pem_pk8.c +132 -119
- data/third_party/boringssl/crypto/pem/pem_pkey.c +144 -220
- data/third_party/boringssl/crypto/pem/pem_x509.c +3 -3
- data/third_party/boringssl/crypto/pem/pem_xaux.c +5 -4
- data/third_party/boringssl/crypto/pkcs8/pkcs8.c +54 -60
- data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +3 -1
- data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +48 -50
- data/third_party/boringssl/crypto/rand/rand.c +2 -0
- data/third_party/boringssl/crypto/rsa/blinding.c +8 -48
- data/third_party/boringssl/crypto/rsa/internal.h +1 -9
- data/third_party/boringssl/crypto/rsa/padding.c +73 -77
- data/third_party/boringssl/crypto/rsa/rsa.c +1 -1
- data/third_party/boringssl/crypto/rsa/rsa_asn1.c +27 -46
- data/third_party/boringssl/crypto/rsa/rsa_impl.c +23 -34
- data/third_party/boringssl/crypto/test/scoped_types.h +3 -0
- data/third_party/boringssl/crypto/thread_win.c +15 -13
- data/third_party/boringssl/crypto/time_support.c +0 -6
- data/third_party/boringssl/crypto/x509/a_digest.c +26 -27
- data/third_party/boringssl/crypto/x509/a_sign.c +63 -64
- data/third_party/boringssl/crypto/x509/a_strex.c +482 -413
- data/third_party/boringssl/crypto/x509/a_verify.c +45 -51
- data/third_party/boringssl/crypto/x509/asn1_gen.c +715 -769
- data/third_party/boringssl/crypto/x509/by_dir.c +355 -393
- data/third_party/boringssl/crypto/x509/by_file.c +186 -206
- data/third_party/boringssl/crypto/x509/charmap.h +11 -11
- data/third_party/boringssl/crypto/x509/i2d_pr.c +21 -22
- data/third_party/boringssl/crypto/x509/t_crl.c +50 -51
- data/third_party/boringssl/crypto/x509/t_x509.c +414 -406
- data/third_party/boringssl/crypto/x509/t_x509a.c +44 -42
- data/third_party/boringssl/crypto/x509/vpm_int.h +13 -13
- data/third_party/boringssl/crypto/x509/x509_att.c +241 -219
- data/third_party/boringssl/crypto/x509/x509_cmp.c +343 -359
- data/third_party/boringssl/crypto/x509/x509_d2.c +36 -35
- data/third_party/boringssl/crypto/x509/x509_def.c +23 -13
- data/third_party/boringssl/crypto/x509/x509_ext.c +75 -75
- data/third_party/boringssl/crypto/x509/x509_lu.c +574 -612
- data/third_party/boringssl/crypto/x509/x509_obj.c +104 -115
- data/third_party/boringssl/crypto/x509/x509_r2x.c +40 -40
- data/third_party/boringssl/crypto/x509/x509_req.c +181 -174
- data/third_party/boringssl/crypto/x509/x509_set.c +71 -76
- data/third_party/boringssl/crypto/x509/x509_trs.c +193 -171
- data/third_party/boringssl/crypto/x509/x509_txt.c +135 -138
- data/third_party/boringssl/crypto/x509/x509_v3.c +174 -167
- data/third_party/boringssl/crypto/x509/x509_vfy.c +2079 -2130
- data/third_party/boringssl/crypto/x509/x509_vpm.c +486 -522
- data/third_party/boringssl/crypto/x509/x509cset.c +96 -99
- data/third_party/boringssl/crypto/x509/x509name.c +280 -275
- data/third_party/boringssl/crypto/x509/x509rset.c +15 -14
- data/third_party/boringssl/crypto/x509/x509spki.c +62 -60
- data/third_party/boringssl/crypto/x509/x509type.c +58 -60
- data/third_party/boringssl/crypto/x509/x_algor.c +70 -73
- data/third_party/boringssl/crypto/x509/x_all.c +282 -328
- data/third_party/boringssl/crypto/x509/x_attrib.c +36 -42
- data/third_party/boringssl/crypto/x509/x_crl.c +397 -418
- data/third_party/boringssl/crypto/x509/x_exten.c +5 -5
- data/third_party/boringssl/crypto/x509/x_info.c +30 -27
- data/third_party/boringssl/crypto/x509/x_name.c +387 -388
- data/third_party/boringssl/crypto/x509/x_pkey.c +32 -29
- data/third_party/boringssl/crypto/x509/x_pubkey.c +261 -280
- data/third_party/boringssl/crypto/x509/x_req.c +30 -33
- data/third_party/boringssl/crypto/x509/x_sig.c +2 -2
- data/third_party/boringssl/crypto/x509/x_spki.c +9 -7
- data/third_party/boringssl/crypto/x509/x_val.c +2 -2
- data/third_party/boringssl/crypto/x509/x_x509.c +120 -119
- data/third_party/boringssl/crypto/x509/x_x509a.c +99 -91
- data/third_party/boringssl/crypto/x509v3/ext_dat.h +57 -51
- data/third_party/boringssl/crypto/x509v3/pcy_cache.c +199 -214
- data/third_party/boringssl/crypto/x509v3/pcy_data.c +57 -64
- data/third_party/boringssl/crypto/x509v3/pcy_int.h +95 -90
- data/third_party/boringssl/crypto/x509v3/pcy_lib.c +86 -87
- data/third_party/boringssl/crypto/x509v3/pcy_map.c +61 -64
- data/third_party/boringssl/crypto/x509v3/pcy_node.c +108 -117
- data/third_party/boringssl/crypto/x509v3/pcy_tree.c +676 -724
- data/third_party/boringssl/crypto/x509v3/v3_akey.c +128 -136
- data/third_party/boringssl/crypto/x509v3/v3_akeya.c +7 -6
- data/third_party/boringssl/crypto/x509v3/v3_alt.c +499 -507
- data/third_party/boringssl/crypto/x509v3/v3_bcons.c +54 -47
- data/third_party/boringssl/crypto/x509v3/v3_bitst.c +67 -67
- data/third_party/boringssl/crypto/x509v3/v3_conf.c +330 -328
- data/third_party/boringssl/crypto/x509v3/v3_cpols.c +354 -338
- data/third_party/boringssl/crypto/x509v3/v3_crld.c +441 -496
- data/third_party/boringssl/crypto/x509v3/v3_enum.c +35 -33
- data/third_party/boringssl/crypto/x509v3/v3_extku.c +66 -63
- data/third_party/boringssl/crypto/x509v3/v3_genn.c +157 -159
- data/third_party/boringssl/crypto/x509v3/v3_ia5.c +45 -43
- data/third_party/boringssl/crypto/x509v3/v3_info.c +124 -112
- data/third_party/boringssl/crypto/x509v3/v3_int.c +30 -26
- data/third_party/boringssl/crypto/x509v3/v3_lib.c +231 -204
- data/third_party/boringssl/crypto/x509v3/v3_ncons.c +353 -381
- data/third_party/boringssl/crypto/x509v3/v3_pci.c +252 -270
- data/third_party/boringssl/crypto/x509v3/v3_pcia.c +9 -8
- data/third_party/boringssl/crypto/x509v3/v3_pcons.c +58 -61
- data/third_party/boringssl/crypto/x509v3/v3_pku.c +35 -34
- data/third_party/boringssl/crypto/x509v3/v3_pmaps.c +72 -74
- data/third_party/boringssl/crypto/x509v3/v3_prn.c +146 -121
- data/third_party/boringssl/crypto/x509v3/v3_purp.c +651 -582
- data/third_party/boringssl/crypto/x509v3/v3_skey.c +76 -72
- data/third_party/boringssl/crypto/x509v3/v3_sxnet.c +139 -131
- data/third_party/boringssl/crypto/x509v3/v3_utl.c +1072 -1068
- data/third_party/boringssl/include/openssl/asn1.h +40 -38
- data/third_party/boringssl/include/openssl/base.h +10 -1
- data/third_party/boringssl/include/openssl/bio.h +10 -11
- data/third_party/boringssl/include/openssl/bn.h +12 -9
- data/third_party/boringssl/include/openssl/buf.h +1 -1
- data/third_party/boringssl/include/openssl/bytestring.h +29 -0
- data/third_party/boringssl/include/openssl/conf.h +25 -0
- data/third_party/boringssl/include/openssl/crypto.h +6 -1
- data/third_party/boringssl/include/openssl/curve25519.h +6 -3
- data/third_party/boringssl/include/openssl/dh.h +7 -3
- data/third_party/boringssl/include/openssl/dsa.h +108 -51
- data/third_party/boringssl/include/openssl/ec.h +46 -21
- data/third_party/boringssl/include/openssl/ec_key.h +78 -42
- data/third_party/boringssl/include/openssl/ecdsa.h +4 -4
- data/third_party/boringssl/include/openssl/err.h +3 -2
- data/third_party/boringssl/include/openssl/evp.h +120 -37
- data/third_party/boringssl/include/openssl/mem.h +4 -13
- data/third_party/boringssl/include/openssl/obj_mac.h +4 -0
- data/third_party/boringssl/include/openssl/pem.h +0 -9
- data/third_party/boringssl/include/openssl/pkcs8.h +6 -2
- data/third_party/boringssl/include/openssl/rand.h +3 -0
- data/third_party/boringssl/include/openssl/rsa.h +42 -42
- data/third_party/boringssl/include/openssl/ssl.h +115 -41
- data/third_party/boringssl/include/openssl/stack.h +0 -3
- data/third_party/boringssl/include/openssl/stack_macros.h +0 -256
- data/third_party/boringssl/include/openssl/tls1.h +1 -1
- data/third_party/boringssl/include/openssl/x509.h +0 -2
- data/third_party/boringssl/include/openssl/x509_vfy.h +5 -0
- data/third_party/boringssl/ssl/d1_both.c +102 -101
- data/third_party/boringssl/ssl/d1_clnt.c +145 -150
- data/third_party/boringssl/ssl/d1_lib.c +63 -62
- data/third_party/boringssl/ssl/d1_pkt.c +73 -71
- data/third_party/boringssl/ssl/d1_srvr.c +116 -125
- data/third_party/boringssl/ssl/dtls_record.c +3 -3
- data/third_party/boringssl/ssl/internal.h +210 -208
- data/third_party/boringssl/ssl/pqueue/pqueue.c +2 -2
- data/third_party/boringssl/ssl/s3_both.c +116 -130
- data/third_party/boringssl/ssl/s3_clnt.c +589 -740
- data/third_party/boringssl/ssl/s3_enc.c +52 -151
- data/third_party/boringssl/ssl/s3_lib.c +70 -76
- data/third_party/boringssl/ssl/s3_pkt.c +105 -144
- data/third_party/boringssl/ssl/s3_srvr.c +542 -806
- data/third_party/boringssl/ssl/ssl_aead_ctx.c +1 -1
- data/third_party/boringssl/ssl/ssl_cert.c +2 -2
- data/third_party/boringssl/ssl/ssl_cipher.c +7 -3
- data/third_party/boringssl/ssl/ssl_ecdh.c +374 -0
- data/third_party/boringssl/ssl/ssl_lib.c +260 -221
- data/third_party/boringssl/ssl/ssl_session.c +17 -17
- data/third_party/boringssl/ssl/t1_enc.c +128 -273
- data/third_party/boringssl/ssl/t1_lib.c +134 -258
- data/third_party/boringssl/ssl/test/test_config.h +2 -0
- data/third_party/boringssl/ssl/tls_record.c +52 -15
- metadata +385 -359
- data/src/core/channel/client_uchannel.c +0 -243
- data/src/core/channel/client_uchannel.h +0 -60
- data/src/core/channel/connected_channel.h +0 -51
- data/src/core/client_config/lb_policies/pick_first.h +0 -43
- data/src/core/client_config/resolvers/dns_resolver.h +0 -42
- data/src/core/client_config/subchannel_factory.h +0 -66
- data/src/core/httpcli/parser.c +0 -211
- data/src/core/iomgr/fd_posix.c +0 -451
- data/src/core/iomgr/fd_posix.h +0 -192
- data/src/core/iomgr/pollset_multipoller_with_epoll.c +0 -324
- data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +0 -234
- data/src/core/iomgr/pollset_posix.c +0 -633
- data/src/core/iomgr/pollset_posix.h +0 -153
- data/src/core/iomgr/pollset_set_posix.c +0 -202
- data/src/core/iomgr/pollset_set_posix.h +0 -45
- data/src/core/surface/init.c +0 -174
- data/src/core/surface/init_secure.c +0 -42
- data/src/core/surface/server_create.c +0 -48
- data/src/core/transport/chttp2/huffsyms.c +0 -297
- data/src/ruby/bin/grpc_ruby_interop_client +0 -33
- data/src/ruby/bin/grpc_ruby_interop_server +0 -33
- data/third_party/boringssl/crypto/dsa/internal.h +0 -78
@@ -31,10 +31,10 @@
|
|
31
31
|
*
|
32
32
|
*/
|
33
33
|
|
34
|
-
#ifndef
|
35
|
-
#define
|
34
|
+
#ifndef GRPC_CORE_LIB_TSI_FAKE_TRANSPORT_SECURITY_H
|
35
|
+
#define GRPC_CORE_LIB_TSI_FAKE_TRANSPORT_SECURITY_H
|
36
36
|
|
37
|
-
#include "src/core/tsi/transport_security_interface.h"
|
37
|
+
#include "src/core/lib/tsi/transport_security_interface.h"
|
38
38
|
|
39
39
|
#ifdef __cplusplus
|
40
40
|
extern "C" {
|
@@ -58,4 +58,4 @@ tsi_frame_protector *tsi_create_fake_protector(
|
|
58
58
|
}
|
59
59
|
#endif
|
60
60
|
|
61
|
-
#endif /*
|
61
|
+
#endif /* GRPC_CORE_LIB_TSI_FAKE_TRANSPORT_SECURITY_H */
|
@@ -31,11 +31,21 @@
|
|
31
31
|
*
|
32
32
|
*/
|
33
33
|
|
34
|
-
#include "src/core/tsi/ssl_transport_security.h"
|
34
|
+
#include "src/core/lib/tsi/ssl_transport_security.h"
|
35
|
+
|
36
|
+
#include <grpc/support/port_platform.h>
|
35
37
|
|
36
38
|
#include <limits.h>
|
37
39
|
#include <string.h>
|
38
40
|
|
41
|
+
/* TODO(jboeuf): refactor inet_ntop into a portability header. */
|
42
|
+
#ifdef GPR_WINSOCK_SOCKET
|
43
|
+
#include <ws2tcpip.h>
|
44
|
+
#else
|
45
|
+
#include <arpa/inet.h>
|
46
|
+
#endif
|
47
|
+
|
48
|
+
#include <grpc/support/alloc.h>
|
39
49
|
#include <grpc/support/log.h>
|
40
50
|
#include <grpc/support/sync.h>
|
41
51
|
#include <grpc/support/thd.h>
|
@@ -48,8 +58,8 @@
|
|
48
58
|
#include <openssl/x509.h>
|
49
59
|
#include <openssl/x509v3.h>
|
50
60
|
|
51
|
-
#include "src/core/tsi/ssl_types.h"
|
52
|
-
#include "src/core/tsi/transport_security.h"
|
61
|
+
#include "src/core/lib/tsi/ssl_types.h"
|
62
|
+
#include "src/core/lib/tsi/transport_security.h"
|
53
63
|
|
54
64
|
/* --- Constants. ---*/
|
55
65
|
|
@@ -139,8 +149,7 @@ static void init_openssl(void) {
|
|
139
149
|
OpenSSL_add_all_algorithms();
|
140
150
|
num_locks = CRYPTO_num_locks();
|
141
151
|
GPR_ASSERT(num_locks > 0);
|
142
|
-
openssl_mutexes =
|
143
|
-
GPR_ASSERT(openssl_mutexes != NULL);
|
152
|
+
openssl_mutexes = gpr_malloc((size_t)num_locks * sizeof(gpr_mu));
|
144
153
|
for (i = 0; i < CRYPTO_num_locks(); i++) {
|
145
154
|
gpr_mu_init(&openssl_mutexes[i]);
|
146
155
|
}
|
@@ -197,13 +206,16 @@ static void ssl_info_callback(const SSL *ssl, int where, int ret) {
|
|
197
206
|
}
|
198
207
|
|
199
208
|
/* Returns 1 if name looks like an IP address, 0 otherwise.
|
200
|
-
This is a very rough heuristic
|
201
|
-
0300.0250.00.01, 0xC0.0Xa8.0x0.0x1, 000030052000001, 0xc0.052000001 */
|
209
|
+
This is a very rough heuristic, and only handles IPv6 in hexadecimal form. */
|
202
210
|
static int looks_like_ip_address(const char *name) {
|
203
211
|
size_t i;
|
204
212
|
size_t dot_count = 0;
|
205
213
|
size_t num_size = 0;
|
206
214
|
for (i = 0; i < strlen(name); i++) {
|
215
|
+
if (name[i] == ':') {
|
216
|
+
/* IPv6 Address in hexadecimal form, : is not allowed in DNS names. */
|
217
|
+
return 1;
|
218
|
+
}
|
207
219
|
if (name[i] >= '0' && name[i] <= '9') {
|
208
220
|
if (num_size > 3) return 0;
|
209
221
|
num_size++;
|
@@ -281,6 +293,26 @@ static tsi_result peer_property_from_x509_common_name(
|
|
281
293
|
return result;
|
282
294
|
}
|
283
295
|
|
296
|
+
/* Gets the X509 cert in PEM format as a tsi_peer_property. */
|
297
|
+
static tsi_result add_pem_certificate(X509 *cert, tsi_peer_property *property) {
|
298
|
+
BIO *bio = BIO_new(BIO_s_mem());
|
299
|
+
if (!PEM_write_bio_X509(bio, cert)) {
|
300
|
+
BIO_free(bio);
|
301
|
+
return TSI_INTERNAL_ERROR;
|
302
|
+
}
|
303
|
+
char *contents;
|
304
|
+
long len = BIO_get_mem_data(bio, &contents);
|
305
|
+
if (len <= 0) {
|
306
|
+
BIO_free(bio);
|
307
|
+
return TSI_INTERNAL_ERROR;
|
308
|
+
}
|
309
|
+
tsi_result result = tsi_construct_string_peer_property(
|
310
|
+
TSI_X509_PEM_CERT_PROPERTY, (const char *)contents, (size_t)len,
|
311
|
+
property);
|
312
|
+
BIO_free(bio);
|
313
|
+
return result;
|
314
|
+
}
|
315
|
+
|
284
316
|
/* Gets the subject SANs from an X509 cert as a tsi_peer_property. */
|
285
317
|
static tsi_result add_subject_alt_names_properties_to_peer(
|
286
318
|
tsi_peer *peer, GENERAL_NAMES *subject_alt_names,
|
@@ -296,21 +328,44 @@ static tsi_result add_subject_alt_names_properties_to_peer(
|
|
296
328
|
sk_GENERAL_NAME_value(subject_alt_names, TSI_SIZE_AS_SIZE(i));
|
297
329
|
/* Filter out the non-dns entries names. */
|
298
330
|
if (subject_alt_name->type == GEN_DNS) {
|
299
|
-
unsigned char *
|
300
|
-
int
|
301
|
-
|
302
|
-
if (
|
331
|
+
unsigned char *name = NULL;
|
332
|
+
int name_size;
|
333
|
+
name_size = ASN1_STRING_to_UTF8(&name, subject_alt_name->d.dNSName);
|
334
|
+
if (name_size < 0) {
|
303
335
|
gpr_log(GPR_ERROR, "Could not get utf8 from asn1 string.");
|
304
336
|
result = TSI_INTERNAL_ERROR;
|
305
337
|
break;
|
306
338
|
}
|
307
339
|
result = tsi_construct_string_peer_property(
|
308
|
-
TSI_X509_SUBJECT_ALTERNATIVE_NAME_PEER_PROPERTY,
|
309
|
-
(
|
340
|
+
TSI_X509_SUBJECT_ALTERNATIVE_NAME_PEER_PROPERTY, (const char *)name,
|
341
|
+
(size_t)name_size, &peer->properties[peer->property_count++]);
|
342
|
+
OPENSSL_free(name);
|
343
|
+
} else if (subject_alt_name->type == GEN_IPADD) {
|
344
|
+
char ntop_buf[INET6_ADDRSTRLEN];
|
345
|
+
int af;
|
346
|
+
|
347
|
+
if (subject_alt_name->d.iPAddress->length == 4) {
|
348
|
+
af = AF_INET;
|
349
|
+
} else if (subject_alt_name->d.iPAddress->length == 16) {
|
350
|
+
af = AF_INET6;
|
351
|
+
} else {
|
352
|
+
gpr_log(GPR_ERROR, "SAN IP Address contained invalid IP");
|
353
|
+
result = TSI_INTERNAL_ERROR;
|
354
|
+
break;
|
355
|
+
}
|
356
|
+
const char *name = inet_ntop(af, subject_alt_name->d.iPAddress->data,
|
357
|
+
ntop_buf, INET6_ADDRSTRLEN);
|
358
|
+
if (name == NULL) {
|
359
|
+
gpr_log(GPR_ERROR, "Could not get IP string from asn1 octet.");
|
360
|
+
result = TSI_INTERNAL_ERROR;
|
361
|
+
break;
|
362
|
+
}
|
363
|
+
|
364
|
+
result = tsi_construct_string_peer_property_from_cstring(
|
365
|
+
TSI_X509_SUBJECT_ALTERNATIVE_NAME_PEER_PROPERTY, name,
|
310
366
|
&peer->properties[peer->property_count++]);
|
311
|
-
OPENSSL_free(dns_name);
|
312
|
-
if (result != TSI_OK) break;
|
313
367
|
}
|
368
|
+
if (result != TSI_OK) break;
|
314
369
|
}
|
315
370
|
return result;
|
316
371
|
}
|
@@ -328,7 +383,8 @@ static tsi_result peer_from_x509(X509 *cert, int include_certificate_type,
|
|
328
383
|
tsi_result result;
|
329
384
|
GPR_ASSERT(subject_alt_name_count >= 0);
|
330
385
|
property_count = (include_certificate_type ? (size_t)1 : 0) +
|
331
|
-
|
386
|
+
2 /* common name, certificate */ +
|
387
|
+
(size_t)subject_alt_name_count;
|
332
388
|
result = tsi_construct_peer(property_count, peer);
|
333
389
|
if (result != TSI_OK) return result;
|
334
390
|
do {
|
@@ -342,6 +398,10 @@ static tsi_result peer_from_x509(X509 *cert, int include_certificate_type,
|
|
342
398
|
cert, &peer->properties[include_certificate_type ? 1 : 0]);
|
343
399
|
if (result != TSI_OK) break;
|
344
400
|
|
401
|
+
result = add_pem_certificate(
|
402
|
+
cert, &peer->properties[include_certificate_type ? 2 : 1]);
|
403
|
+
if (result != TSI_OK) break;
|
404
|
+
|
345
405
|
if (subject_alt_name_count != 0) {
|
346
406
|
result = add_subject_alt_names_properties_to_peer(
|
347
407
|
peer, subject_alt_names, (size_t)subject_alt_name_count);
|
@@ -641,7 +701,7 @@ static tsi_result build_alpn_protocol_name_list(
|
|
641
701
|
}
|
642
702
|
*protocol_name_list_length += (size_t)alpn_protocols_lengths[i] + 1;
|
643
703
|
}
|
644
|
-
*protocol_name_list =
|
704
|
+
*protocol_name_list = gpr_malloc(*protocol_name_list_length);
|
645
705
|
if (*protocol_name_list == NULL) return TSI_OUT_OF_RESOURCES;
|
646
706
|
current = *protocol_name_list;
|
647
707
|
for (i = 0; i < num_alpn_protocols; i++) {
|
@@ -658,6 +718,14 @@ static tsi_result build_alpn_protocol_name_list(
|
|
658
718
|
return TSI_OK;
|
659
719
|
}
|
660
720
|
|
721
|
+
// The verification callback is used for clients that don't really care about
|
722
|
+
// the server's certificate, but we need to pull it anyway, in case a higher
|
723
|
+
// layer wants to look at it. In this case the verification may fail, but
|
724
|
+
// we don't really care.
|
725
|
+
static int NullVerifyCallback(int preverify_ok, X509_STORE_CTX *ctx) {
|
726
|
+
return 1;
|
727
|
+
}
|
728
|
+
|
661
729
|
/* --- tsi_frame_protector methods implementation. ---*/
|
662
730
|
|
663
731
|
static tsi_result ssl_protector_protect(tsi_frame_protector *self,
|
@@ -792,9 +860,9 @@ static tsi_result ssl_protector_unprotect(
|
|
792
860
|
|
793
861
|
static void ssl_protector_destroy(tsi_frame_protector *self) {
|
794
862
|
tsi_ssl_frame_protector *impl = (tsi_ssl_frame_protector *)self;
|
795
|
-
if (impl->buffer != NULL)
|
863
|
+
if (impl->buffer != NULL) gpr_free(impl->buffer);
|
796
864
|
if (impl->ssl != NULL) SSL_free(impl->ssl);
|
797
|
-
|
865
|
+
gpr_free(self);
|
798
866
|
}
|
799
867
|
|
800
868
|
static const tsi_frame_protector_vtable frame_protector_vtable = {
|
@@ -906,8 +974,9 @@ static tsi_result ssl_handshaker_extract_peer(tsi_handshaker *self,
|
|
906
974
|
if (alpn_selected != NULL) {
|
907
975
|
size_t i;
|
908
976
|
tsi_peer_property *new_properties =
|
909
|
-
|
910
|
-
|
977
|
+
gpr_malloc(sizeof(*new_properties) * (peer->property_count + 1));
|
978
|
+
memset(new_properties, 0,
|
979
|
+
sizeof(*new_properties) * (peer->property_count + 1));
|
911
980
|
for (i = 0; i < peer->property_count; i++) {
|
912
981
|
new_properties[i] = peer->properties[i];
|
913
982
|
}
|
@@ -915,10 +984,10 @@ static tsi_result ssl_handshaker_extract_peer(tsi_handshaker *self,
|
|
915
984
|
TSI_SSL_ALPN_SELECTED_PROTOCOL, (const char *)alpn_selected,
|
916
985
|
alpn_selected_len, &new_properties[peer->property_count]);
|
917
986
|
if (result != TSI_OK) {
|
918
|
-
|
987
|
+
gpr_free(new_properties);
|
919
988
|
return result;
|
920
989
|
}
|
921
|
-
if (peer->properties != NULL)
|
990
|
+
if (peer->properties != NULL) gpr_free(peer->properties);
|
922
991
|
peer->property_count++;
|
923
992
|
peer->properties = new_properties;
|
924
993
|
}
|
@@ -931,11 +1000,8 @@ static tsi_result ssl_handshaker_create_frame_protector(
|
|
931
1000
|
size_t actual_max_output_protected_frame_size =
|
932
1001
|
TSI_SSL_MAX_PROTECTED_FRAME_SIZE_UPPER_BOUND;
|
933
1002
|
tsi_ssl_handshaker *impl = (tsi_ssl_handshaker *)self;
|
934
|
-
tsi_ssl_frame_protector *protector_impl =
|
935
|
-
|
936
|
-
if (protector_impl == NULL) {
|
937
|
-
return TSI_OUT_OF_RESOURCES;
|
938
|
-
}
|
1003
|
+
tsi_ssl_frame_protector *protector_impl = gpr_malloc(sizeof(*protector_impl));
|
1004
|
+
memset(protector_impl, 0, sizeof(*protector_impl));
|
939
1005
|
|
940
1006
|
if (max_output_protected_frame_size != NULL) {
|
941
1007
|
if (*max_output_protected_frame_size >
|
@@ -951,11 +1017,11 @@ static tsi_result ssl_handshaker_create_frame_protector(
|
|
951
1017
|
}
|
952
1018
|
protector_impl->buffer_size =
|
953
1019
|
actual_max_output_protected_frame_size - TSI_SSL_MAX_PROTECTION_OVERHEAD;
|
954
|
-
protector_impl->buffer =
|
1020
|
+
protector_impl->buffer = gpr_malloc(protector_impl->buffer_size);
|
955
1021
|
if (protector_impl->buffer == NULL) {
|
956
1022
|
gpr_log(GPR_ERROR,
|
957
1023
|
"Could not allocated buffer for tsi_ssl_frame_protector.");
|
958
|
-
|
1024
|
+
gpr_free(protector_impl);
|
959
1025
|
return TSI_INTERNAL_ERROR;
|
960
1026
|
}
|
961
1027
|
|
@@ -974,13 +1040,15 @@ static tsi_result ssl_handshaker_create_frame_protector(
|
|
974
1040
|
static void ssl_handshaker_destroy(tsi_handshaker *self) {
|
975
1041
|
tsi_ssl_handshaker *impl = (tsi_ssl_handshaker *)self;
|
976
1042
|
SSL_free(impl->ssl); /* The BIO objects are owned by ssl */
|
977
|
-
|
1043
|
+
gpr_free(impl);
|
978
1044
|
}
|
979
1045
|
|
980
1046
|
static const tsi_handshaker_vtable handshaker_vtable = {
|
981
1047
|
ssl_handshaker_get_bytes_to_send_to_peer,
|
982
|
-
ssl_handshaker_process_bytes_from_peer,
|
983
|
-
|
1048
|
+
ssl_handshaker_process_bytes_from_peer,
|
1049
|
+
ssl_handshaker_get_result,
|
1050
|
+
ssl_handshaker_extract_peer,
|
1051
|
+
ssl_handshaker_create_frame_protector,
|
984
1052
|
ssl_handshaker_destroy,
|
985
1053
|
};
|
986
1054
|
|
@@ -1049,11 +1117,8 @@ static tsi_result create_tsi_ssl_handshaker(SSL_CTX *ctx, int is_client,
|
|
1049
1117
|
SSL_set_accept_state(ssl);
|
1050
1118
|
}
|
1051
1119
|
|
1052
|
-
impl =
|
1053
|
-
|
1054
|
-
SSL_free(ssl);
|
1055
|
-
return TSI_OUT_OF_RESOURCES;
|
1056
|
-
}
|
1120
|
+
impl = gpr_malloc(sizeof(*impl));
|
1121
|
+
memset(impl, 0, sizeof(*impl));
|
1057
1122
|
impl->ssl = ssl;
|
1058
1123
|
impl->into_ssl = into_ssl;
|
1059
1124
|
impl->from_ssl = from_ssl;
|
@@ -1105,8 +1170,8 @@ static void ssl_client_handshaker_factory_destroy(
|
|
1105
1170
|
tsi_ssl_client_handshaker_factory *impl =
|
1106
1171
|
(tsi_ssl_client_handshaker_factory *)self;
|
1107
1172
|
if (impl->ssl_context != NULL) SSL_CTX_free(impl->ssl_context);
|
1108
|
-
if (impl->alpn_protocol_list != NULL)
|
1109
|
-
|
1173
|
+
if (impl->alpn_protocol_list != NULL) gpr_free(impl->alpn_protocol_list);
|
1174
|
+
gpr_free(impl);
|
1110
1175
|
}
|
1111
1176
|
|
1112
1177
|
static int client_handshaker_factory_npn_callback(SSL *ssl, unsigned char **out,
|
@@ -1147,12 +1212,12 @@ static void ssl_server_handshaker_factory_destroy(
|
|
1147
1212
|
tsi_peer_destruct(&impl->ssl_context_x509_subject_names[i]);
|
1148
1213
|
}
|
1149
1214
|
}
|
1150
|
-
if (impl->ssl_contexts != NULL)
|
1215
|
+
if (impl->ssl_contexts != NULL) gpr_free(impl->ssl_contexts);
|
1151
1216
|
if (impl->ssl_context_x509_subject_names != NULL) {
|
1152
|
-
|
1217
|
+
gpr_free(impl->ssl_context_x509_subject_names);
|
1153
1218
|
}
|
1154
|
-
if (impl->alpn_protocol_list != NULL)
|
1155
|
-
|
1219
|
+
if (impl->alpn_protocol_list != NULL) gpr_free(impl->alpn_protocol_list);
|
1220
|
+
gpr_free(impl);
|
1156
1221
|
}
|
1157
1222
|
|
1158
1223
|
static int does_entry_match_name(const char *entry, size_t entry_length,
|
@@ -1271,11 +1336,8 @@ tsi_result tsi_create_ssl_client_handshaker_factory(
|
|
1271
1336
|
return TSI_INVALID_ARGUMENT;
|
1272
1337
|
}
|
1273
1338
|
|
1274
|
-
impl =
|
1275
|
-
|
1276
|
-
SSL_CTX_free(ssl_context);
|
1277
|
-
return TSI_OUT_OF_RESOURCES;
|
1278
|
-
}
|
1339
|
+
impl = gpr_malloc(sizeof(*impl));
|
1340
|
+
memset(impl, 0, sizeof(*impl));
|
1279
1341
|
impl->ssl_context = ssl_context;
|
1280
1342
|
|
1281
1343
|
do {
|
@@ -1336,6 +1398,26 @@ tsi_result tsi_create_ssl_server_handshaker_factory(
|
|
1336
1398
|
const char *cipher_list, const unsigned char **alpn_protocols,
|
1337
1399
|
const unsigned char *alpn_protocols_lengths, uint16_t num_alpn_protocols,
|
1338
1400
|
tsi_ssl_handshaker_factory **factory) {
|
1401
|
+
return tsi_create_ssl_server_handshaker_factory_ex(
|
1402
|
+
pem_private_keys, pem_private_keys_sizes, pem_cert_chains,
|
1403
|
+
pem_cert_chains_sizes, key_cert_pair_count, pem_client_root_certs,
|
1404
|
+
pem_client_root_certs_size,
|
1405
|
+
force_client_auth ? TSI_REQUEST_AND_REQUIRE_CLIENT_CERTIFICATE_AND_VERIFY
|
1406
|
+
: TSI_DONT_REQUEST_CLIENT_CERTIFICATE,
|
1407
|
+
cipher_list, alpn_protocols, alpn_protocols_lengths, num_alpn_protocols,
|
1408
|
+
factory);
|
1409
|
+
}
|
1410
|
+
|
1411
|
+
tsi_result tsi_create_ssl_server_handshaker_factory_ex(
|
1412
|
+
const unsigned char **pem_private_keys,
|
1413
|
+
const size_t *pem_private_keys_sizes, const unsigned char **pem_cert_chains,
|
1414
|
+
const size_t *pem_cert_chains_sizes, size_t key_cert_pair_count,
|
1415
|
+
const unsigned char *pem_client_root_certs,
|
1416
|
+
size_t pem_client_root_certs_size,
|
1417
|
+
tsi_client_certificate_request_type client_certificate_request,
|
1418
|
+
const char *cipher_list, const unsigned char **alpn_protocols,
|
1419
|
+
const unsigned char *alpn_protocols_lengths, uint16_t num_alpn_protocols,
|
1420
|
+
tsi_ssl_handshaker_factory **factory) {
|
1339
1421
|
tsi_ssl_server_handshaker_factory *impl = NULL;
|
1340
1422
|
tsi_result result = TSI_OK;
|
1341
1423
|
size_t i = 0;
|
@@ -1349,14 +1431,17 @@ tsi_result tsi_create_ssl_server_handshaker_factory(
|
|
1349
1431
|
return TSI_INVALID_ARGUMENT;
|
1350
1432
|
}
|
1351
1433
|
|
1352
|
-
impl =
|
1353
|
-
|
1434
|
+
impl = gpr_malloc(sizeof(*impl));
|
1435
|
+
memset(impl, 0, sizeof(*impl));
|
1354
1436
|
impl->base.create_handshaker =
|
1355
1437
|
ssl_server_handshaker_factory_create_handshaker;
|
1356
1438
|
impl->base.destroy = ssl_server_handshaker_factory_destroy;
|
1357
|
-
impl->ssl_contexts =
|
1439
|
+
impl->ssl_contexts = gpr_malloc(key_cert_pair_count * sizeof(SSL_CTX *));
|
1440
|
+
memset(impl->ssl_contexts, 0, key_cert_pair_count * sizeof(SSL_CTX *));
|
1358
1441
|
impl->ssl_context_x509_subject_names =
|
1359
|
-
|
1442
|
+
gpr_malloc(key_cert_pair_count * sizeof(tsi_peer));
|
1443
|
+
memset(impl->ssl_context_x509_subject_names, 0,
|
1444
|
+
key_cert_pair_count * sizeof(tsi_peer));
|
1360
1445
|
if (impl->ssl_contexts == NULL ||
|
1361
1446
|
impl->ssl_context_x509_subject_names == NULL) {
|
1362
1447
|
tsi_ssl_handshaker_factory_destroy(&impl->base);
|
@@ -1388,7 +1473,6 @@ tsi_result tsi_create_ssl_server_handshaker_factory(
|
|
1388
1473
|
if (result != TSI_OK) break;
|
1389
1474
|
|
1390
1475
|
if (pem_client_root_certs != NULL) {
|
1391
|
-
int flags = SSL_VERIFY_PEER;
|
1392
1476
|
STACK_OF(X509_NAME) *root_names = NULL;
|
1393
1477
|
result = ssl_ctx_load_verification_certs(
|
1394
1478
|
impl->ssl_contexts[i], pem_client_root_certs,
|
@@ -1398,8 +1482,29 @@ tsi_result tsi_create_ssl_server_handshaker_factory(
|
|
1398
1482
|
break;
|
1399
1483
|
}
|
1400
1484
|
SSL_CTX_set_client_CA_list(impl->ssl_contexts[i], root_names);
|
1401
|
-
|
1402
|
-
|
1485
|
+
switch (client_certificate_request) {
|
1486
|
+
case TSI_DONT_REQUEST_CLIENT_CERTIFICATE:
|
1487
|
+
SSL_CTX_set_verify(impl->ssl_contexts[i], SSL_VERIFY_NONE, NULL);
|
1488
|
+
break;
|
1489
|
+
case TSI_REQUEST_CLIENT_CERTIFICATE_BUT_DONT_VERIFY:
|
1490
|
+
SSL_CTX_set_verify(impl->ssl_contexts[i], SSL_VERIFY_PEER,
|
1491
|
+
NullVerifyCallback);
|
1492
|
+
break;
|
1493
|
+
case TSI_REQUEST_CLIENT_CERTIFICATE_AND_VERIFY:
|
1494
|
+
SSL_CTX_set_verify(impl->ssl_contexts[i], SSL_VERIFY_PEER, NULL);
|
1495
|
+
break;
|
1496
|
+
case TSI_REQUEST_AND_REQUIRE_CLIENT_CERTIFICATE_BUT_DONT_VERIFY:
|
1497
|
+
SSL_CTX_set_verify(
|
1498
|
+
impl->ssl_contexts[i],
|
1499
|
+
SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT,
|
1500
|
+
NullVerifyCallback);
|
1501
|
+
break;
|
1502
|
+
case TSI_REQUEST_AND_REQUIRE_CLIENT_CERTIFICATE_AND_VERIFY:
|
1503
|
+
SSL_CTX_set_verify(
|
1504
|
+
impl->ssl_contexts[i],
|
1505
|
+
SSL_VERIFY_PEER | SSL_VERIFY_FAIL_IF_NO_PEER_CERT, NULL);
|
1506
|
+
break;
|
1507
|
+
}
|
1403
1508
|
/* TODO(jboeuf): Add revocation verification. */
|
1404
1509
|
}
|
1405
1510
|
|
@@ -1436,9 +1541,7 @@ int tsi_ssl_peer_matches_name(const tsi_peer *peer, const char *name) {
|
|
1436
1541
|
size_t i = 0;
|
1437
1542
|
size_t san_count = 0;
|
1438
1543
|
const tsi_peer_property *cn_property = NULL;
|
1439
|
-
|
1440
|
-
/* For now reject what looks like an IP address. */
|
1441
|
-
if (looks_like_ip_address(name)) return 0;
|
1544
|
+
int like_ip = looks_like_ip_address(name);
|
1442
1545
|
|
1443
1546
|
/* Check the SAN first. */
|
1444
1547
|
for (i = 0; i < peer->property_count; i++) {
|
@@ -1447,8 +1550,15 @@ int tsi_ssl_peer_matches_name(const tsi_peer *peer, const char *name) {
|
|
1447
1550
|
if (strcmp(property->name,
|
1448
1551
|
TSI_X509_SUBJECT_ALTERNATIVE_NAME_PEER_PROPERTY) == 0) {
|
1449
1552
|
san_count++;
|
1450
|
-
|
1451
|
-
|
1553
|
+
|
1554
|
+
if (!like_ip && does_entry_match_name(property->value.data,
|
1555
|
+
property->value.length, name)) {
|
1556
|
+
return 1;
|
1557
|
+
} else if (like_ip &&
|
1558
|
+
strncmp(name, property->value.data, property->value.length) ==
|
1559
|
+
0 &&
|
1560
|
+
strlen(name) == property->value.length) {
|
1561
|
+
/* IP Addresses are exact matches only. */
|
1452
1562
|
return 1;
|
1453
1563
|
}
|
1454
1564
|
} else if (strcmp(property->name,
|
@@ -1457,8 +1567,8 @@ int tsi_ssl_peer_matches_name(const tsi_peer *peer, const char *name) {
|
|
1457
1567
|
}
|
1458
1568
|
}
|
1459
1569
|
|
1460
|
-
/* If there's no SAN, try the CN
|
1461
|
-
if (san_count == 0 && cn_property != NULL) {
|
1570
|
+
/* If there's no SAN, try the CN, but only if its not like an IP Address */
|
1571
|
+
if (san_count == 0 && cn_property != NULL && !like_ip) {
|
1462
1572
|
if (does_entry_match_name(cn_property->value.data,
|
1463
1573
|
cn_property->value.length, name)) {
|
1464
1574
|
return 1;
|