grpc 1.36.0 → 1.38.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of grpc might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Makefile +126 -92
- data/include/grpc/event_engine/README.md +38 -0
- data/include/grpc/event_engine/channel_args.h +28 -0
- data/include/grpc/event_engine/event_engine.h +336 -0
- data/include/grpc/event_engine/port.h +39 -0
- data/include/grpc/event_engine/slice_allocator.h +81 -0
- data/include/grpc/grpc.h +15 -1
- data/include/grpc/grpc_security_constants.h +14 -0
- data/include/grpc/impl/codegen/grpc_types.h +11 -0
- data/include/grpc/impl/codegen/port_platform.h +7 -0
- data/include/grpc/module.modulemap +14 -14
- data/src/core/ext/filters/client_channel/backup_poller.cc +3 -3
- data/src/core/ext/filters/client_channel/channel_connectivity.cc +177 -202
- data/src/core/ext/filters/client_channel/client_channel.cc +715 -3166
- data/src/core/ext/filters/client_channel/client_channel.h +489 -55
- data/src/core/ext/filters/client_channel/client_channel_channelz.h +1 -1
- data/src/core/ext/filters/client_channel/client_channel_factory.h +2 -1
- data/src/core/ext/filters/client_channel/client_channel_plugin.cc +4 -1
- data/src/core/ext/filters/client_channel/config_selector.h +9 -1
- data/src/core/ext/filters/client_channel/connector.h +1 -1
- data/src/core/ext/filters/client_channel/dynamic_filters.cc +18 -14
- data/src/core/ext/filters/client_channel/dynamic_filters.h +3 -3
- data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +24 -142
- data/src/core/ext/filters/client_channel/global_subchannel_pool.h +15 -10
- data/src/core/ext/filters/client_channel/health/health_check_client.cc +26 -27
- data/src/core/ext/filters/client_channel/health/health_check_client.h +27 -26
- data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +24 -21
- data/src/core/ext/filters/client_channel/lb_policy.cc +4 -1
- data/src/core/ext/filters/client_channel/lb_policy.h +4 -4
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +6 -6
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +46 -43
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +2 -1
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +5 -5
- data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +14 -12
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +23 -0
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +27 -0
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +4 -4
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +15 -15
- data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +36 -30
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +29 -44
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +32 -47
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +86 -63
- data/src/core/ext/filters/client_channel/lb_policy_factory.h +1 -1
- data/src/core/ext/filters/client_channel/lb_policy_registry.cc +4 -4
- data/src/core/ext/filters/client_channel/lb_policy_registry.h +1 -1
- data/src/core/ext/filters/client_channel/local_subchannel_pool.cc +27 -67
- data/src/core/ext/filters/client_channel/local_subchannel_pool.h +10 -9
- data/src/core/ext/filters/client_channel/resolver.cc +3 -0
- data/src/core/ext/filters/client_channel/resolver.h +2 -2
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +23 -15
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_libuv.cc +3 -3
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -4
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +17 -15
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +38 -33
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +17 -9
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +20 -28
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +7 -5
- data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +31 -14
- data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +334 -114
- data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +32 -239
- data/src/core/ext/filters/client_channel/resolver_result_parsing.h +20 -49
- data/src/core/ext/filters/client_channel/retry_filter.cc +2188 -0
- data/src/core/ext/filters/client_channel/retry_filter.h +30 -0
- data/src/core/ext/filters/client_channel/retry_service_config.cc +287 -0
- data/src/core/ext/filters/client_channel/retry_service_config.h +90 -0
- data/src/core/ext/filters/client_channel/server_address.cc +4 -1
- data/src/core/ext/filters/client_channel/service_config.cc +15 -14
- data/src/core/ext/filters/client_channel/service_config.h +7 -6
- data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +5 -4
- data/src/core/ext/filters/client_channel/service_config_parser.cc +6 -6
- data/src/core/ext/filters/client_channel/service_config_parser.h +7 -4
- data/src/core/ext/filters/client_channel/subchannel.cc +86 -162
- data/src/core/ext/filters/client_channel/subchannel.h +68 -99
- data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +16 -2
- data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +10 -8
- data/src/core/ext/filters/client_idle/client_idle_filter.cc +17 -16
- data/src/core/ext/filters/deadline/deadline_filter.cc +10 -10
- data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +501 -0
- data/src/core/ext/filters/fault_injection/fault_injection_filter.h +39 -0
- data/src/core/ext/filters/fault_injection/service_config_parser.cc +189 -0
- data/src/core/ext/filters/fault_injection/service_config_parser.h +85 -0
- data/src/core/ext/filters/http/client/http_client_filter.cc +28 -21
- data/src/core/ext/filters/http/client_authority_filter.cc +3 -3
- data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +23 -22
- data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +21 -21
- data/src/core/ext/filters/http/server/http_server_filter.cc +27 -23
- data/src/core/ext/filters/max_age/max_age_filter.cc +12 -10
- data/src/core/ext/filters/message_size/message_size_filter.cc +14 -11
- data/src/core/ext/filters/message_size/message_size_filter.h +1 -1
- data/src/core/ext/filters/workarounds/workaround_cronet_compression_filter.cc +5 -4
- data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +8 -8
- data/src/core/ext/transport/chttp2/client/chttp2_connector.h +7 -7
- data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +5 -4
- data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +2 -2
- data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +6 -5
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +485 -199
- data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -2
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +3 -4
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +3 -3
- data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +3 -4
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +167 -122
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +12 -1
- data/src/core/ext/transport/chttp2/transport/context_list.cc +4 -5
- data/src/core/ext/transport/chttp2/transport/context_list.h +4 -4
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +3 -3
- data/src/core/ext/transport/chttp2/transport/flow_control.h +8 -8
- data/src/core/ext/transport/chttp2/transport/frame_data.cc +13 -9
- data/src/core/ext/transport/chttp2/transport/frame_data.h +10 -10
- data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +7 -8
- data/src/core/ext/transport/chttp2/transport/frame_goaway.h +6 -6
- data/src/core/ext/transport/chttp2/transport/frame_ping.cc +7 -8
- data/src/core/ext/transport/chttp2/transport/frame_ping.h +7 -6
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +7 -7
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +6 -6
- data/src/core/ext/transport/chttp2/transport/frame_settings.cc +6 -5
- data/src/core/ext/transport/chttp2/transport/frame_settings.h +6 -6
- data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +4 -6
- data/src/core/ext/transport/chttp2/transport/frame_window_update.h +4 -6
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +1 -1
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +237 -208
- data/src/core/ext/transport/chttp2/transport/hpack_parser.h +10 -10
- data/src/core/ext/transport/chttp2/transport/hpack_table.cc +4 -3
- data/src/core/ext/transport/chttp2/transport/hpack_table.h +4 -4
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.cc +2 -2
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.h +2 -2
- data/src/core/ext/transport/chttp2/transport/internal.h +32 -27
- data/src/core/ext/transport/chttp2/transport/parsing.cc +63 -56
- data/src/core/ext/transport/chttp2/transport/writing.cc +7 -3
- data/src/core/ext/transport/inproc/inproc_transport.cc +30 -29
- data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +406 -0
- data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +1459 -0
- data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +350 -0
- data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1348 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +6 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +25 -0
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +144 -0
- data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +488 -0
- data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +141 -0
- data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +452 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +15 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +44 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +79 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +268 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +78 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +281 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +41 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +113 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +6 -5
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +13 -9
- data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +93 -0
- data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +323 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +36 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +90 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +46 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +124 -0
- data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.c +33 -0
- data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.h +77 -0
- data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +354 -0
- data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +140 -0
- data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +383 -0
- data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +115 -0
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +10 -7
- data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +5 -0
- data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +141 -0
- data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +70 -0
- data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +141 -0
- data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +70 -0
- data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +13 -7
- data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +5 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +102 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +55 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +120 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +45 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +76 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +35 -0
- data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +21 -20
- data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +130 -0
- data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +50 -0
- data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +56 -0
- data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +35 -0
- data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +63 -0
- data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +40 -0
- data/src/core/ext/upbdefs-generated/udpa/type/v1/typed_struct.upbdefs.c +44 -0
- data/src/core/ext/upbdefs-generated/udpa/type/v1/typed_struct.upbdefs.h +35 -0
- data/src/core/ext/xds/certificate_provider_factory.h +1 -1
- data/src/core/ext/xds/certificate_provider_store.h +3 -3
- data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +3 -3
- data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +2 -2
- data/src/core/ext/xds/xds_api.cc +1649 -329
- data/src/core/ext/xds/xds_api.h +284 -44
- data/src/core/ext/xds/xds_bootstrap.cc +110 -156
- data/src/core/ext/xds/xds_bootstrap.h +24 -25
- data/src/core/ext/xds/xds_certificate_provider.cc +4 -4
- data/src/core/ext/xds/xds_certificate_provider.h +4 -4
- data/src/core/ext/xds/xds_channel_args.h +5 -2
- data/src/core/ext/xds/xds_client.cc +454 -177
- data/src/core/ext/xds/xds_client.h +62 -22
- data/src/core/ext/xds/xds_client_stats.h +5 -4
- data/src/core/ext/xds/xds_http_fault_filter.cc +226 -0
- data/src/core/ext/xds/xds_http_fault_filter.h +63 -0
- data/src/core/ext/xds/xds_http_filters.cc +114 -0
- data/src/core/ext/xds/xds_http_filters.h +130 -0
- data/src/core/ext/xds/xds_server_config_fetcher.cc +410 -131
- data/src/core/lib/{iomgr → address_utils}/parse_address.cc +17 -17
- data/src/core/lib/{iomgr → address_utils}/parse_address.h +7 -7
- data/src/core/lib/{iomgr → address_utils}/sockaddr_utils.cc +107 -4
- data/src/core/lib/{iomgr → address_utils}/sockaddr_utils.h +26 -6
- data/src/core/lib/channel/channel_stack.cc +22 -9
- data/src/core/lib/channel/channel_stack.h +17 -9
- data/src/core/lib/channel/channel_stack_builder.cc +2 -2
- data/src/core/lib/channel/channel_stack_builder.h +1 -1
- data/src/core/lib/channel/channelz.cc +108 -12
- data/src/core/lib/channel/channelz.h +30 -1
- data/src/core/lib/channel/channelz_registry.cc +14 -0
- data/src/core/lib/channel/connected_channel.cc +4 -4
- data/src/core/lib/channel/handshaker.cc +7 -45
- data/src/core/lib/channel/handshaker.h +5 -22
- data/src/core/lib/channel/status_util.cc +12 -2
- data/src/core/lib/channel/status_util.h +5 -0
- data/src/core/lib/event_engine/slice_allocator.cc +59 -0
- data/src/core/lib/event_engine/sockaddr.cc +38 -0
- data/src/core/lib/gpr/sync_abseil.cc +3 -6
- data/src/core/lib/gpr/sync_windows.cc +2 -2
- data/src/core/lib/gprpp/atomic.h +3 -3
- data/src/core/lib/gprpp/dual_ref_counted.h +3 -3
- data/src/core/lib/gprpp/ref_counted.h +28 -14
- data/src/core/lib/gprpp/ref_counted_ptr.h +2 -0
- data/src/core/lib/gprpp/status_helper.cc +407 -0
- data/src/core/lib/gprpp/status_helper.h +180 -0
- data/src/core/lib/gprpp/thd.h +1 -1
- data/src/core/lib/http/httpcli.cc +11 -11
- data/src/core/lib/http/httpcli_security_connector.cc +11 -7
- data/src/core/lib/http/parser.cc +16 -16
- data/src/core/lib/http/parser.h +4 -4
- data/src/core/lib/iomgr/buffer_list.cc +7 -9
- data/src/core/lib/iomgr/buffer_list.h +5 -6
- data/src/core/lib/iomgr/call_combiner.cc +15 -12
- data/src/core/lib/iomgr/call_combiner.h +12 -14
- data/src/core/lib/iomgr/cfstream_handle.cc +5 -5
- data/src/core/lib/iomgr/cfstream_handle.h +1 -1
- data/src/core/lib/iomgr/closure.h +7 -6
- data/src/core/lib/iomgr/combiner.cc +14 -12
- data/src/core/lib/iomgr/combiner.h +2 -2
- data/src/core/lib/iomgr/endpoint.cc +1 -1
- data/src/core/lib/iomgr/endpoint.h +2 -2
- data/src/core/lib/iomgr/endpoint_cfstream.cc +11 -13
- data/src/core/lib/iomgr/endpoint_pair_windows.cc +1 -1
- data/src/core/lib/iomgr/error.cc +167 -61
- data/src/core/lib/iomgr/error.h +218 -107
- data/src/core/lib/iomgr/error_cfstream.cc +3 -2
- data/src/core/lib/iomgr/error_cfstream.h +2 -2
- data/src/core/lib/iomgr/error_internal.h +5 -1
- data/src/core/lib/iomgr/ev_apple.cc +6 -6
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +22 -22
- data/src/core/lib/iomgr/ev_epollex_linux.cc +48 -45
- data/src/core/lib/iomgr/ev_poll_posix.cc +26 -23
- data/src/core/lib/iomgr/ev_posix.cc +12 -11
- data/src/core/lib/iomgr/ev_posix.h +9 -9
- data/src/core/lib/iomgr/exec_ctx.cc +10 -6
- data/src/core/lib/iomgr/exec_ctx.h +1 -1
- data/src/core/lib/iomgr/executor.cc +8 -8
- data/src/core/lib/iomgr/executor.h +2 -2
- data/src/core/lib/iomgr/iomgr.cc +1 -1
- data/src/core/lib/iomgr/iomgr.h +1 -1
- data/src/core/lib/iomgr/iomgr_custom.cc +1 -1
- data/src/core/lib/iomgr/iomgr_internal.cc +2 -2
- data/src/core/lib/iomgr/iomgr_internal.h +3 -3
- data/src/core/lib/iomgr/iomgr_posix.cc +1 -1
- data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +2 -2
- data/src/core/lib/iomgr/iomgr_windows.cc +1 -1
- data/src/core/lib/iomgr/load_file.cc +4 -4
- data/src/core/lib/iomgr/load_file.h +2 -2
- data/src/core/lib/iomgr/lockfree_event.cc +5 -5
- data/src/core/lib/iomgr/lockfree_event.h +1 -1
- data/src/core/lib/iomgr/pollset.cc +5 -5
- data/src/core/lib/iomgr/pollset.h +9 -9
- data/src/core/lib/iomgr/pollset_custom.cc +5 -5
- data/src/core/lib/iomgr/pollset_windows.cc +5 -5
- data/src/core/lib/iomgr/port.h +1 -1
- data/src/core/lib/iomgr/python_util.h +1 -1
- data/src/core/lib/iomgr/resolve_address.cc +3 -3
- data/src/core/lib/iomgr/resolve_address.h +6 -6
- data/src/core/lib/iomgr/resolve_address_custom.cc +10 -9
- data/src/core/lib/iomgr/resolve_address_custom.h +3 -3
- data/src/core/lib/iomgr/resolve_address_posix.cc +3 -3
- data/src/core/lib/iomgr/resolve_address_windows.cc +4 -4
- data/src/core/lib/iomgr/resource_quota.cc +12 -11
- data/src/core/lib/iomgr/socket_utils_common_posix.cc +22 -20
- data/src/core/lib/iomgr/socket_utils_posix.h +20 -20
- data/src/core/lib/iomgr/tcp_client_cfstream.cc +4 -4
- data/src/core/lib/iomgr/tcp_client_custom.cc +5 -6
- data/src/core/lib/iomgr/tcp_client_posix.cc +15 -17
- data/src/core/lib/iomgr/tcp_client_posix.h +3 -4
- data/src/core/lib/iomgr/tcp_client_windows.cc +5 -5
- data/src/core/lib/iomgr/tcp_custom.cc +14 -16
- data/src/core/lib/iomgr/tcp_custom.h +13 -12
- data/src/core/lib/iomgr/tcp_posix.cc +37 -38
- data/src/core/lib/iomgr/tcp_server.cc +6 -6
- data/src/core/lib/iomgr/tcp_server.h +12 -11
- data/src/core/lib/iomgr/tcp_server_custom.cc +23 -21
- data/src/core/lib/iomgr/tcp_server_posix.cc +22 -21
- data/src/core/lib/iomgr/tcp_server_utils_posix.h +13 -12
- data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +19 -17
- data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +9 -9
- data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +4 -4
- data/src/core/lib/iomgr/tcp_server_windows.cc +26 -25
- data/src/core/lib/iomgr/tcp_uv.cc +27 -25
- data/src/core/lib/iomgr/tcp_windows.cc +13 -13
- data/src/core/lib/iomgr/tcp_windows.h +2 -2
- data/src/core/lib/iomgr/timer_custom.cc +2 -1
- data/src/core/lib/iomgr/timer_custom.h +1 -1
- data/src/core/lib/iomgr/timer_generic.cc +8 -8
- data/src/core/lib/iomgr/timer_manager.cc +1 -1
- data/src/core/lib/iomgr/udp_server.cc +21 -20
- data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -3
- data/src/core/lib/iomgr/unix_sockets_posix.h +2 -2
- data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +10 -7
- data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +3 -3
- data/src/core/lib/iomgr/wakeup_fd_nospecial.cc +1 -1
- data/src/core/lib/iomgr/wakeup_fd_pipe.cc +4 -4
- data/src/core/lib/iomgr/wakeup_fd_posix.cc +3 -3
- data/src/core/lib/iomgr/wakeup_fd_posix.h +8 -6
- data/src/core/lib/iomgr/work_serializer.h +17 -1
- data/src/core/lib/json/json.h +1 -1
- data/src/core/lib/json/json_reader.cc +4 -4
- data/src/core/lib/{security/authorization → matchers}/matchers.cc +47 -47
- data/src/core/lib/{security/authorization → matchers}/matchers.h +42 -40
- data/src/core/lib/security/credentials/composite/composite_credentials.cc +4 -4
- data/src/core/lib/security/credentials/composite/composite_credentials.h +2 -2
- data/src/core/lib/security/credentials/credentials.h +2 -2
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +17 -13
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +13 -11
- data/src/core/lib/security/credentials/external/aws_request_signer.cc +2 -1
- data/src/core/lib/security/credentials/external/aws_request_signer.h +1 -1
- data/src/core/lib/security/credentials/external/external_account_credentials.cc +15 -12
- data/src/core/lib/security/credentials/external/external_account_credentials.h +9 -8
- data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +5 -4
- data/src/core/lib/security/credentials/external/file_external_account_credentials.h +4 -3
- data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +8 -8
- data/src/core/lib/security/credentials/external/url_external_account_credentials.h +9 -7
- data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -2
- data/src/core/lib/security/credentials/fake/fake_credentials.h +2 -2
- data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +9 -9
- data/src/core/lib/security/credentials/iam/iam_credentials.cc +2 -2
- data/src/core/lib/security/credentials/iam/iam_credentials.h +2 -2
- data/src/core/lib/security/credentials/jwt/json_token.cc +2 -2
- data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +3 -3
- data/src/core/lib/security/credentials/jwt/jwt_credentials.h +2 -2
- data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +7 -5
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +21 -19
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +5 -5
- data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +5 -5
- data/src/core/lib/security/credentials/plugin/plugin_credentials.h +2 -2
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +8 -7
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +9 -9
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +19 -13
- data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -0
- data/src/core/lib/security/credentials/xds/xds_credentials.cc +3 -3
- data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +13 -3
- data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +13 -3
- data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +2 -2
- data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +12 -2
- data/src/core/lib/security/security_connector/load_system_roots_linux.cc +1 -1
- data/src/core/lib/security/security_connector/local/local_security_connector.cc +14 -4
- data/src/core/lib/security/security_connector/security_connector.h +9 -4
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +16 -6
- data/src/core/lib/security/security_connector/ssl_utils.cc +28 -8
- data/src/core/lib/security/security_connector/ssl_utils.h +4 -4
- data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +62 -60
- data/src/core/lib/security/security_connector/tls/tls_security_connector.h +66 -48
- data/src/core/lib/security/transport/client_auth_filter.cc +18 -10
- data/src/core/lib/security/transport/secure_endpoint.cc +4 -4
- data/src/core/lib/security/transport/security_handshaker.cc +65 -34
- data/src/core/lib/security/transport/server_auth_filter.cc +24 -11
- data/src/core/lib/security/transport/tsi_error.cc +2 -1
- data/src/core/lib/security/transport/tsi_error.h +2 -1
- data/src/core/lib/security/util/json_util.cc +2 -2
- data/src/core/lib/security/util/json_util.h +1 -1
- data/src/core/lib/slice/slice_intern.cc +6 -7
- data/src/core/lib/surface/call.cc +46 -45
- data/src/core/lib/surface/call.h +2 -2
- data/src/core/lib/surface/channel.cc +6 -6
- data/src/core/lib/surface/channel.h +6 -5
- data/src/core/lib/surface/channel_ping.cc +1 -1
- data/src/core/lib/surface/completion_queue.cc +46 -47
- data/src/core/lib/surface/completion_queue.h +2 -1
- data/src/core/lib/surface/lame_client.cc +43 -24
- data/src/core/lib/surface/lame_client.h +4 -3
- data/src/core/lib/surface/server.cc +68 -55
- data/src/core/lib/surface/server.h +89 -29
- data/src/core/lib/surface/validate_metadata.cc +7 -7
- data/src/core/lib/surface/validate_metadata.h +3 -2
- data/src/core/lib/surface/version.cc +4 -2
- data/src/core/lib/transport/byte_stream.cc +5 -5
- data/src/core/lib/transport/byte_stream.h +8 -8
- data/src/core/lib/transport/connectivity_state.cc +1 -1
- data/src/core/lib/transport/error_utils.cc +19 -8
- data/src/core/lib/transport/error_utils.h +11 -5
- data/src/core/lib/transport/metadata_batch.cc +64 -37
- data/src/core/lib/transport/metadata_batch.h +33 -18
- data/src/core/lib/transport/transport.cc +4 -3
- data/src/core/lib/transport/transport.h +4 -4
- data/src/core/lib/transport/transport_op_string.cc +5 -5
- data/src/core/plugin_registry/grpc_plugin_registry.cc +6 -0
- data/src/core/tsi/alts/crypt/gsec.h +4 -0
- data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +6 -8
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +7 -6
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +1 -1
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker_private.h +2 -1
- data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +1 -3
- data/src/core/tsi/fake_transport_security.cc +10 -1
- data/src/core/tsi/ssl_transport_security.cc +32 -14
- data/src/core/tsi/ssl_transport_security.h +3 -4
- data/src/ruby/bin/math_services_pb.rb +1 -1
- data/src/ruby/ext/grpc/extconf.rb +9 -1
- data/src/ruby/ext/grpc/rb_channel.c +10 -1
- data/src/ruby/ext/grpc/rb_channel_credentials.c +11 -1
- data/src/ruby/ext/grpc/rb_channel_credentials.h +4 -0
- data/src/ruby/ext/grpc/rb_compression_options.c +1 -1
- data/src/ruby/ext/grpc/rb_enable_cpp.cc +1 -1
- data/src/ruby/ext/grpc/rb_grpc.c +4 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +2 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +4 -1
- data/src/ruby/ext/grpc/rb_server.c +13 -1
- data/src/ruby/ext/grpc/rb_server_credentials.c +19 -3
- data/src/ruby/ext/grpc/rb_server_credentials.h +4 -0
- data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +215 -0
- data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +35 -0
- data/src/ruby/ext/grpc/rb_xds_server_credentials.c +169 -0
- data/src/ruby/ext/grpc/rb_xds_server_credentials.h +35 -0
- data/src/ruby/lib/grpc/generic/client_stub.rb +4 -2
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/v1/health_services_pb.rb +1 -1
- data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +6 -6
- data/src/ruby/spec/call_spec.rb +1 -1
- data/src/ruby/spec/channel_credentials_spec.rb +32 -0
- data/src/ruby/spec/channel_spec.rb +17 -6
- data/src/ruby/spec/client_auth_spec.rb +27 -1
- data/src/ruby/spec/errors_spec.rb +1 -1
- data/src/ruby/spec/generic/active_call_spec.rb +2 -2
- data/src/ruby/spec/generic/client_stub_spec.rb +4 -4
- data/src/ruby/spec/generic/rpc_server_spec.rb +1 -1
- data/src/ruby/spec/server_credentials_spec.rb +25 -0
- data/src/ruby/spec/server_spec.rb +22 -0
- data/third_party/abseil-cpp/absl/algorithm/container.h +3 -3
- data/third_party/abseil-cpp/absl/base/attributes.h +24 -4
- data/third_party/abseil-cpp/absl/base/call_once.h +2 -9
- data/third_party/abseil-cpp/absl/base/config.h +37 -9
- data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +24 -10
- data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +4 -1
- data/third_party/abseil-cpp/absl/base/internal/endian.h +61 -0
- data/third_party/abseil-cpp/absl/base/internal/low_level_scheduling.h +2 -3
- data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +34 -32
- data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +16 -6
- data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +11 -2
- data/third_party/abseil-cpp/absl/base/internal/spinlock.h +14 -5
- data/third_party/abseil-cpp/absl/base/internal/spinlock_akaros.inc +2 -2
- data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +3 -3
- data/third_party/abseil-cpp/absl/base/internal/spinlock_posix.inc +2 -2
- data/third_party/abseil-cpp/absl/base/internal/spinlock_wait.h +11 -11
- data/third_party/abseil-cpp/absl/base/internal/spinlock_win32.inc +5 -5
- data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +1 -1
- data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +5 -2
- data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +43 -42
- data/third_party/abseil-cpp/absl/base/internal/throw_delegate.cc +111 -7
- data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +0 -76
- data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +1 -3
- data/third_party/abseil-cpp/absl/base/log_severity.h +4 -4
- data/third_party/abseil-cpp/absl/base/macros.h +11 -0
- data/third_party/abseil-cpp/absl/base/optimization.h +10 -7
- data/third_party/abseil-cpp/absl/base/options.h +1 -1
- data/third_party/abseil-cpp/absl/base/port.h +0 -1
- data/third_party/abseil-cpp/absl/base/thread_annotations.h +1 -1
- data/third_party/abseil-cpp/absl/container/fixed_array.h +2 -2
- data/third_party/abseil-cpp/absl/container/inlined_vector.h +5 -3
- data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +1 -1
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +5 -1
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +2 -1
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +2 -1
- data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +141 -66
- data/third_party/abseil-cpp/absl/container/internal/layout.h +4 -4
- data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +14 -1
- data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +136 -136
- data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +16 -12
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +5 -2
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +3 -12
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +6 -1
- data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +3 -5
- data/third_party/abseil-cpp/absl/debugging/symbolize_darwin.inc +2 -2
- data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +2 -2
- data/third_party/abseil-cpp/absl/hash/internal/city.cc +15 -12
- data/third_party/abseil-cpp/absl/hash/internal/city.h +1 -19
- data/third_party/abseil-cpp/absl/hash/internal/hash.cc +25 -10
- data/third_party/abseil-cpp/absl/hash/internal/hash.h +86 -37
- data/third_party/abseil-cpp/absl/hash/internal/wyhash.cc +111 -0
- data/third_party/abseil-cpp/absl/hash/internal/wyhash.h +48 -0
- data/third_party/abseil-cpp/absl/meta/type_traits.h +16 -2
- data/third_party/abseil-cpp/absl/numeric/bits.h +177 -0
- data/third_party/abseil-cpp/absl/numeric/int128.cc +3 -3
- data/third_party/abseil-cpp/absl/numeric/internal/bits.h +358 -0
- data/third_party/abseil-cpp/absl/numeric/internal/representation.h +55 -0
- data/third_party/abseil-cpp/absl/status/internal/status_internal.h +18 -0
- data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +4 -7
- data/third_party/abseil-cpp/absl/status/status.cc +29 -22
- data/third_party/abseil-cpp/absl/status/status.h +81 -20
- data/third_party/abseil-cpp/absl/status/statusor.h +3 -3
- data/third_party/abseil-cpp/absl/strings/charconv.cc +5 -5
- data/third_party/abseil-cpp/absl/strings/cord.cc +326 -371
- data/third_party/abseil-cpp/absl/strings/cord.h +182 -64
- data/third_party/abseil-cpp/absl/strings/escaping.cc +4 -4
- data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.cc +6 -6
- data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +83 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +387 -17
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +146 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +897 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.h +589 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring_reader.h +114 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +14 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +14 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.cc +15 -1
- data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +19 -4
- data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +14 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +36 -18
- data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +14 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.cc +14 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +14 -0
- data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +15 -40
- data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +64 -0
- data/third_party/abseil-cpp/absl/strings/match.cc +6 -3
- data/third_party/abseil-cpp/absl/strings/match.h +16 -6
- data/third_party/abseil-cpp/absl/strings/numbers.cc +132 -4
- data/third_party/abseil-cpp/absl/strings/numbers.h +10 -10
- data/third_party/abseil-cpp/absl/strings/str_join.h +1 -1
- data/third_party/abseil-cpp/absl/strings/str_split.h +38 -4
- data/third_party/abseil-cpp/absl/synchronization/internal/futex.h +154 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +2 -1
- data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +2 -2
- data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +4 -4
- data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +1 -65
- data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +2 -6
- data/third_party/abseil-cpp/absl/synchronization/mutex.cc +71 -59
- data/third_party/abseil-cpp/absl/synchronization/mutex.h +79 -62
- data/third_party/abseil-cpp/absl/time/clock.cc +146 -130
- data/third_party/abseil-cpp/absl/time/clock.h +2 -2
- data/third_party/abseil-cpp/absl/time/duration.cc +3 -2
- data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +7 -11
- data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +7 -1
- data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +4 -4
- data/third_party/abseil-cpp/absl/time/time.cc +4 -3
- data/third_party/abseil-cpp/absl/time/time.h +26 -24
- data/third_party/abseil-cpp/absl/types/internal/variant.h +1 -1
- data/third_party/abseil-cpp/absl/types/variant.h +9 -4
- data/third_party/boringssl-with-bazel/err_data.c +478 -462
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +18 -8
- data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +1 -2
- data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_locl.h +5 -0
- data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +1 -88
- data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +14 -3
- data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +119 -273
- data/third_party/boringssl-with-bazel/src/crypto/cpu-arm-linux.c +11 -2
- data/third_party/boringssl-with-bazel/src/crypto/cpu-arm.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/err/err.c +87 -80
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +1 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +32 -16
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +25 -2
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.c +10 -2
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +4 -43
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +4 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +0 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +0 -4
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +104 -93
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +39 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c +43 -46
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/md5.c +43 -46
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +33 -22
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c +9 -8
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +9 -8
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +17 -13
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +1 -22
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +2 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +7 -5
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +26 -7
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +79 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +14 -9
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +45 -48
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +38 -43
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +37 -45
- data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +103 -42
- data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +58 -37
- data/third_party/boringssl-with-bazel/src/crypto/internal.h +65 -0
- data/third_party/boringssl-with-bazel/src/crypto/mem.c +14 -0
- data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +95 -48
- data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +0 -28
- data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +19 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +2 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +19 -25
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +3 -30
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +39 -89
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +9 -16
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +21 -17
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +21 -34
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +5 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +25 -22
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +2 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +3 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +2 -4
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +1 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +0 -3
- data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +120 -41
- data/third_party/boringssl-with-bazel/src/include/openssl/base.h +9 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +0 -4
- data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +22 -32
- data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +24 -4
- data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +5 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +19 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/err.h +3 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +1 -38
- data/third_party/boringssl-with-bazel/src/{crypto/x509/x509_r2x.c → include/openssl/evp_errors.h} +41 -58
- data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +24 -5
- data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +2 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +9 -1
- data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +2 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +210 -26
- data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +1 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +416 -122
- data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +2 -0
- data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +5 -0
- data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +444 -0
- data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +244 -1
- data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +43 -12
- data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +149 -8
- data/third_party/boringssl-with-bazel/src/ssl/internal.h +220 -46
- data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +7 -1
- data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +4 -6
- data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +23 -26
- data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +74 -15
- data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +131 -83
- data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +34 -4
- data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +205 -100
- data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +4 -2
- data/third_party/xxhash/xxhash.h +5443 -0
- metadata +128 -61
- data/src/core/lib/iomgr/poller/eventmanager_libuv.cc +0 -88
- data/src/core/lib/iomgr/poller/eventmanager_libuv.h +0 -88
- data/src/core/lib/security/authorization/authorization_engine.cc +0 -177
- data/src/core/lib/security/authorization/authorization_engine.h +0 -84
- data/src/core/lib/security/authorization/evaluate_args.cc +0 -148
- data/src/core/lib/security/authorization/evaluate_args.h +0 -59
- data/src/core/lib/security/authorization/mock_cel/activation.h +0 -57
- data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +0 -44
- data/src/core/lib/security/authorization/mock_cel/cel_expression.h +0 -69
- data/src/core/lib/security/authorization/mock_cel/cel_value.h +0 -99
- data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +0 -67
- data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +0 -57
- data/third_party/abseil-cpp/absl/base/internal/bits.h +0 -219
- data/third_party/abseil-cpp/absl/container/flat_hash_set.h +0 -504
- data/third_party/abseil-cpp/absl/synchronization/internal/mutex_nonprod.inc +0 -249
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/is_fips.c +0 -29
- data/third_party/upb/upb/json_decode.c +0 -1443
- data/third_party/upb/upb/json_decode.h +0 -23
- data/third_party/upb/upb/json_encode.c +0 -713
- data/third_party/upb/upb/json_encode.h +0 -36
@@ -132,7 +132,7 @@ struct grpc_resource_quota {
|
|
132
132
|
scaled to the range [0..RESOURCE_USAGE_ESTIMATION_MAX] */
|
133
133
|
gpr_atm memory_usage_estimation;
|
134
134
|
|
135
|
-
/*
|
135
|
+
/* Main combiner lock: all activity on a quota executes under this combiner
|
136
136
|
* (so no mutex is needed for this data structure) */
|
137
137
|
grpc_core::Combiner* combiner;
|
138
138
|
/* Size of the resource quota */
|
@@ -276,7 +276,7 @@ static bool rq_reclaim_from_per_user_free_pool(
|
|
276
276
|
grpc_resource_quota* resource_quota);
|
277
277
|
static bool rq_reclaim(grpc_resource_quota* resource_quota, bool destructive);
|
278
278
|
|
279
|
-
static void rq_step(void* rq,
|
279
|
+
static void rq_step(void* rq, grpc_error_handle /*error*/) {
|
280
280
|
grpc_resource_quota* resource_quota = static_cast<grpc_resource_quota*>(rq);
|
281
281
|
resource_quota->step_scheduled = false;
|
282
282
|
do {
|
@@ -484,7 +484,7 @@ static grpc_slice ru_slice_create(grpc_resource_user* resource_user,
|
|
484
484
|
* the combiner
|
485
485
|
*/
|
486
486
|
|
487
|
-
static void ru_allocate(void* ru,
|
487
|
+
static void ru_allocate(void* ru, grpc_error_handle /*error*/) {
|
488
488
|
grpc_resource_user* resource_user = static_cast<grpc_resource_user*>(ru);
|
489
489
|
if (rulist_empty(resource_user->resource_quota,
|
490
490
|
GRPC_RULIST_AWAITING_ALLOCATION)) {
|
@@ -493,7 +493,7 @@ static void ru_allocate(void* ru, grpc_error* /*error*/) {
|
|
493
493
|
rulist_add_tail(resource_user, GRPC_RULIST_AWAITING_ALLOCATION);
|
494
494
|
}
|
495
495
|
|
496
|
-
static void ru_add_to_free_pool(void* ru,
|
496
|
+
static void ru_add_to_free_pool(void* ru, grpc_error_handle /*error*/) {
|
497
497
|
grpc_resource_user* resource_user = static_cast<grpc_resource_user*>(ru);
|
498
498
|
if (!rulist_empty(resource_user->resource_quota,
|
499
499
|
GRPC_RULIST_AWAITING_ALLOCATION) &&
|
@@ -518,7 +518,7 @@ static bool ru_post_reclaimer(grpc_resource_user* resource_user,
|
|
518
518
|
return true;
|
519
519
|
}
|
520
520
|
|
521
|
-
static void ru_post_benign_reclaimer(void* ru,
|
521
|
+
static void ru_post_benign_reclaimer(void* ru, grpc_error_handle /*error*/) {
|
522
522
|
grpc_resource_user* resource_user = static_cast<grpc_resource_user*>(ru);
|
523
523
|
if (!ru_post_reclaimer(resource_user, false)) return;
|
524
524
|
if (!rulist_empty(resource_user->resource_quota,
|
@@ -532,7 +532,8 @@ static void ru_post_benign_reclaimer(void* ru, grpc_error* /*error*/) {
|
|
532
532
|
rulist_add_tail(resource_user, GRPC_RULIST_RECLAIMER_BENIGN);
|
533
533
|
}
|
534
534
|
|
535
|
-
static void ru_post_destructive_reclaimer(void* ru,
|
535
|
+
static void ru_post_destructive_reclaimer(void* ru,
|
536
|
+
grpc_error_handle /*error*/) {
|
536
537
|
grpc_resource_user* resource_user = static_cast<grpc_resource_user*>(ru);
|
537
538
|
if (!ru_post_reclaimer(resource_user, true)) return;
|
538
539
|
if (!rulist_empty(resource_user->resource_quota,
|
@@ -548,7 +549,7 @@ static void ru_post_destructive_reclaimer(void* ru, grpc_error* /*error*/) {
|
|
548
549
|
rulist_add_tail(resource_user, GRPC_RULIST_RECLAIMER_DESTRUCTIVE);
|
549
550
|
}
|
550
551
|
|
551
|
-
static void ru_shutdown(void* ru,
|
552
|
+
static void ru_shutdown(void* ru, grpc_error_handle /*error*/) {
|
552
553
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_resource_quota_trace)) {
|
553
554
|
gpr_log(GPR_INFO, "RU shutdown %p", ru);
|
554
555
|
}
|
@@ -568,7 +569,7 @@ static void ru_shutdown(void* ru, grpc_error* /*error*/) {
|
|
568
569
|
gpr_mu_unlock(&resource_user->mu);
|
569
570
|
}
|
570
571
|
|
571
|
-
static void ru_destroy(void* ru,
|
572
|
+
static void ru_destroy(void* ru, grpc_error_handle /*error*/) {
|
572
573
|
grpc_resource_user* resource_user = static_cast<grpc_resource_user*>(ru);
|
573
574
|
GPR_ASSERT(gpr_atm_no_barrier_load(&resource_user->refs) == 0);
|
574
575
|
// Free all the remaining thread quota
|
@@ -601,7 +602,7 @@ static void ru_alloc_slices(
|
|
601
602
|
}
|
602
603
|
}
|
603
604
|
|
604
|
-
static void ru_allocated_slices(void* arg,
|
605
|
+
static void ru_allocated_slices(void* arg, grpc_error_handle error) {
|
605
606
|
grpc_resource_user_slice_allocator* slice_allocator =
|
606
607
|
static_cast<grpc_resource_user_slice_allocator*>(arg);
|
607
608
|
if (error == GRPC_ERROR_NONE) ru_alloc_slices(slice_allocator);
|
@@ -619,7 +620,7 @@ struct rq_resize_args {
|
|
619
620
|
grpc_resource_quota* resource_quota;
|
620
621
|
grpc_closure closure;
|
621
622
|
};
|
622
|
-
static void rq_resize(void* args,
|
623
|
+
static void rq_resize(void* args, grpc_error_handle /*error*/) {
|
623
624
|
rq_resize_args* a = static_cast<rq_resize_args*>(args);
|
624
625
|
int64_t delta = a->size - a->resource_quota->size;
|
625
626
|
a->resource_quota->size += delta;
|
@@ -630,7 +631,7 @@ static void rq_resize(void* args, grpc_error* /*error*/) {
|
|
630
631
|
gpr_free(a);
|
631
632
|
}
|
632
633
|
|
633
|
-
static void rq_reclamation_done(void* rq,
|
634
|
+
static void rq_reclamation_done(void* rq, grpc_error_handle /*error*/) {
|
634
635
|
grpc_resource_quota* resource_quota = static_cast<grpc_resource_quota*>(rq);
|
635
636
|
resource_quota->reclaiming = false;
|
636
637
|
rq_step_sched(resource_quota);
|
@@ -47,13 +47,13 @@
|
|
47
47
|
#include <grpc/support/log.h>
|
48
48
|
#include <grpc/support/sync.h>
|
49
49
|
|
50
|
+
#include "src/core/lib/address_utils/sockaddr_utils.h"
|
50
51
|
#include "src/core/lib/channel/channel_args.h"
|
51
52
|
#include "src/core/lib/gpr/string.h"
|
52
53
|
#include "src/core/lib/iomgr/sockaddr.h"
|
53
|
-
#include "src/core/lib/iomgr/sockaddr_utils.h"
|
54
54
|
|
55
55
|
/* set a socket to use zerocopy */
|
56
|
-
|
56
|
+
grpc_error_handle grpc_set_socket_zerocopy(int fd) {
|
57
57
|
#ifdef GRPC_LINUX_ERRQUEUE
|
58
58
|
const int enable = 1;
|
59
59
|
auto err = setsockopt(fd, SOL_SOCKET, SO_ZEROCOPY, &enable, sizeof(enable));
|
@@ -68,7 +68,7 @@ grpc_error* grpc_set_socket_zerocopy(int fd) {
|
|
68
68
|
}
|
69
69
|
|
70
70
|
/* set a socket to non blocking mode */
|
71
|
-
|
71
|
+
grpc_error_handle grpc_set_socket_nonblocking(int fd, int non_blocking) {
|
72
72
|
int oldflags = fcntl(fd, F_GETFL, 0);
|
73
73
|
if (oldflags < 0) {
|
74
74
|
return GRPC_OS_ERROR(errno, "fcntl");
|
@@ -87,7 +87,7 @@ grpc_error* grpc_set_socket_nonblocking(int fd, int non_blocking) {
|
|
87
87
|
return GRPC_ERROR_NONE;
|
88
88
|
}
|
89
89
|
|
90
|
-
|
90
|
+
grpc_error_handle grpc_set_socket_no_sigpipe_if_possible(int fd) {
|
91
91
|
#ifdef GRPC_HAVE_SO_NOSIGPIPE
|
92
92
|
int val = 1;
|
93
93
|
int newval;
|
@@ -108,7 +108,7 @@ grpc_error* grpc_set_socket_no_sigpipe_if_possible(int fd) {
|
|
108
108
|
return GRPC_ERROR_NONE;
|
109
109
|
}
|
110
110
|
|
111
|
-
|
111
|
+
grpc_error_handle grpc_set_socket_ip_pktinfo_if_possible(int fd) {
|
112
112
|
// Use conditionally-important parameter to avoid warning
|
113
113
|
(void)fd;
|
114
114
|
#ifdef GRPC_HAVE_IP_PKTINFO
|
@@ -121,7 +121,7 @@ grpc_error* grpc_set_socket_ip_pktinfo_if_possible(int fd) {
|
|
121
121
|
return GRPC_ERROR_NONE;
|
122
122
|
}
|
123
123
|
|
124
|
-
|
124
|
+
grpc_error_handle grpc_set_socket_ipv6_recvpktinfo_if_possible(int fd) {
|
125
125
|
// Use conditionally-important parameter to avoid warning
|
126
126
|
(void)fd;
|
127
127
|
#ifdef GRPC_HAVE_IPV6_RECVPKTINFO
|
@@ -134,14 +134,14 @@ grpc_error* grpc_set_socket_ipv6_recvpktinfo_if_possible(int fd) {
|
|
134
134
|
return GRPC_ERROR_NONE;
|
135
135
|
}
|
136
136
|
|
137
|
-
|
137
|
+
grpc_error_handle grpc_set_socket_sndbuf(int fd, int buffer_size_bytes) {
|
138
138
|
return 0 == setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &buffer_size_bytes,
|
139
139
|
sizeof(buffer_size_bytes))
|
140
140
|
? GRPC_ERROR_NONE
|
141
141
|
: GRPC_OS_ERROR(errno, "setsockopt(SO_SNDBUF)");
|
142
142
|
}
|
143
143
|
|
144
|
-
|
144
|
+
grpc_error_handle grpc_set_socket_rcvbuf(int fd, int buffer_size_bytes) {
|
145
145
|
return 0 == setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &buffer_size_bytes,
|
146
146
|
sizeof(buffer_size_bytes))
|
147
147
|
? GRPC_ERROR_NONE
|
@@ -149,7 +149,7 @@ grpc_error* grpc_set_socket_rcvbuf(int fd, int buffer_size_bytes) {
|
|
149
149
|
}
|
150
150
|
|
151
151
|
/* set a socket to close on exec */
|
152
|
-
|
152
|
+
grpc_error_handle grpc_set_socket_cloexec(int fd, int close_on_exec) {
|
153
153
|
int oldflags = fcntl(fd, F_GETFD, 0);
|
154
154
|
if (oldflags < 0) {
|
155
155
|
return GRPC_OS_ERROR(errno, "fcntl");
|
@@ -169,7 +169,7 @@ grpc_error* grpc_set_socket_cloexec(int fd, int close_on_exec) {
|
|
169
169
|
}
|
170
170
|
|
171
171
|
/* set a socket to reuse old addresses */
|
172
|
-
|
172
|
+
grpc_error_handle grpc_set_socket_reuse_addr(int fd, int reuse) {
|
173
173
|
int val = (reuse != 0);
|
174
174
|
int newval;
|
175
175
|
socklen_t intlen = sizeof(newval);
|
@@ -187,7 +187,7 @@ grpc_error* grpc_set_socket_reuse_addr(int fd, int reuse) {
|
|
187
187
|
}
|
188
188
|
|
189
189
|
/* set a socket to reuse old addresses */
|
190
|
-
|
190
|
+
grpc_error_handle grpc_set_socket_reuse_port(int fd, int reuse) {
|
191
191
|
#ifndef SO_REUSEPORT
|
192
192
|
return GRPC_ERROR_CREATE_FROM_STATIC_STRING(
|
193
193
|
"SO_REUSEPORT unavailable on compiling system");
|
@@ -232,7 +232,7 @@ bool grpc_is_socket_reuse_port_supported() {
|
|
232
232
|
}
|
233
233
|
|
234
234
|
/* disable nagle */
|
235
|
-
|
235
|
+
grpc_error_handle grpc_set_socket_low_latency(int fd, int low_latency) {
|
236
236
|
int val = (low_latency != 0);
|
237
237
|
int newval;
|
238
238
|
socklen_t intlen = sizeof(newval);
|
@@ -297,7 +297,7 @@ void config_default_tcp_user_timeout(bool enable, int timeout, bool is_client) {
|
|
297
297
|
}
|
298
298
|
|
299
299
|
/* Set TCP_USER_TIMEOUT */
|
300
|
-
|
300
|
+
grpc_error_handle grpc_set_socket_tcp_user_timeout(
|
301
301
|
int fd, const grpc_channel_args* channel_args, bool is_client) {
|
302
302
|
// Use conditionally-important parameter to avoid warning
|
303
303
|
(void)fd;
|
@@ -388,7 +388,8 @@ grpc_error* grpc_set_socket_tcp_user_timeout(
|
|
388
388
|
}
|
389
389
|
|
390
390
|
/* set a socket using a grpc_socket_mutator */
|
391
|
-
|
391
|
+
grpc_error_handle grpc_set_socket_with_mutator(int fd,
|
392
|
+
grpc_socket_mutator* mutator) {
|
392
393
|
GPR_ASSERT(mutator);
|
393
394
|
if (!grpc_socket_mutator_mutate_fd(mutator, fd)) {
|
394
395
|
return GRPC_ERROR_CREATE_FROM_STATIC_STRING("grpc_socket_mutator failed.");
|
@@ -396,8 +397,8 @@ grpc_error* grpc_set_socket_with_mutator(int fd, grpc_socket_mutator* mutator) {
|
|
396
397
|
return GRPC_ERROR_NONE;
|
397
398
|
}
|
398
399
|
|
399
|
-
|
400
|
-
|
400
|
+
grpc_error_handle grpc_apply_socket_mutator_in_args(
|
401
|
+
int fd, const grpc_channel_args* args) {
|
401
402
|
const grpc_arg* socket_mutator_arg =
|
402
403
|
grpc_channel_args_find(args, GRPC_ARG_SOCKET_MUTATOR);
|
403
404
|
if (socket_mutator_arg == nullptr) {
|
@@ -437,16 +438,17 @@ int grpc_ipv6_loopback_available(void) {
|
|
437
438
|
return g_ipv6_loopback_available;
|
438
439
|
}
|
439
440
|
|
440
|
-
static
|
441
|
+
static grpc_error_handle error_for_fd(int fd,
|
442
|
+
const grpc_resolved_address* addr) {
|
441
443
|
if (fd >= 0) return GRPC_ERROR_NONE;
|
442
444
|
std::string addr_str = grpc_sockaddr_to_string(addr, false);
|
443
|
-
|
445
|
+
grpc_error_handle err = grpc_error_set_str(
|
444
446
|
GRPC_OS_ERROR(errno, "socket"), GRPC_ERROR_STR_TARGET_ADDRESS,
|
445
447
|
grpc_slice_from_copied_string(addr_str.c_str()));
|
446
448
|
return err;
|
447
449
|
}
|
448
450
|
|
449
|
-
|
451
|
+
grpc_error_handle grpc_create_dualstack_socket(
|
450
452
|
const grpc_resolved_address* resolved_addr, int type, int protocol,
|
451
453
|
grpc_dualstack_mode* dsmode, int* newfd) {
|
452
454
|
return grpc_create_dualstack_socket_using_factory(
|
@@ -460,7 +462,7 @@ static int create_socket(grpc_socket_factory* factory, int domain, int type,
|
|
460
462
|
: socket(domain, type, protocol);
|
461
463
|
}
|
462
464
|
|
463
|
-
|
465
|
+
grpc_error_handle grpc_create_dualstack_socket_using_factory(
|
464
466
|
grpc_socket_factory* factory, const grpc_resolved_address* resolved_addr,
|
465
467
|
int type, int protocol, grpc_dualstack_mode* dsmode, int* newfd) {
|
466
468
|
const grpc_sockaddr* addr =
|
@@ -45,31 +45,31 @@ int grpc_accept4(int sockfd, grpc_resolved_address* resolved_addr, int nonblock,
|
|
45
45
|
int cloexec);
|
46
46
|
|
47
47
|
/* set a socket to use zerocopy */
|
48
|
-
|
48
|
+
grpc_error_handle grpc_set_socket_zerocopy(int fd);
|
49
49
|
|
50
50
|
/* set a socket to non blocking mode */
|
51
|
-
|
51
|
+
grpc_error_handle grpc_set_socket_nonblocking(int fd, int non_blocking);
|
52
52
|
|
53
53
|
/* set a socket to close on exec */
|
54
|
-
|
54
|
+
grpc_error_handle grpc_set_socket_cloexec(int fd, int close_on_exec);
|
55
55
|
|
56
56
|
/* set a socket to reuse old addresses */
|
57
|
-
|
57
|
+
grpc_error_handle grpc_set_socket_reuse_addr(int fd, int reuse);
|
58
58
|
|
59
59
|
/* return true if SO_REUSEPORT is supported */
|
60
60
|
bool grpc_is_socket_reuse_port_supported();
|
61
61
|
|
62
62
|
/* disable nagle */
|
63
|
-
|
63
|
+
grpc_error_handle grpc_set_socket_low_latency(int fd, int low_latency);
|
64
64
|
|
65
65
|
/* set SO_REUSEPORT */
|
66
|
-
|
66
|
+
grpc_error_handle grpc_set_socket_reuse_port(int fd, int reuse);
|
67
67
|
|
68
68
|
/* Configure the default values for TCP_USER_TIMEOUT */
|
69
69
|
void config_default_tcp_user_timeout(bool enable, int timeout, bool is_client);
|
70
70
|
|
71
71
|
/* Set TCP_USER_TIMEOUT */
|
72
|
-
|
72
|
+
grpc_error_handle grpc_set_socket_tcp_user_timeout(
|
73
73
|
int fd, const grpc_channel_args* channel_args, bool is_client);
|
74
74
|
|
75
75
|
/* Returns true if this system can create AF_INET6 sockets bound to ::1.
|
@@ -84,28 +84,29 @@ int grpc_ipv6_loopback_available(void);
|
|
84
84
|
|
85
85
|
/* Tries to set SO_NOSIGPIPE if available on this platform.
|
86
86
|
If SO_NO_SIGPIPE is not available, returns 1. */
|
87
|
-
|
87
|
+
grpc_error_handle grpc_set_socket_no_sigpipe_if_possible(int fd);
|
88
88
|
|
89
89
|
/* Tries to set IP_PKTINFO if available on this platform.
|
90
90
|
If IP_PKTINFO is not available, returns 1. */
|
91
|
-
|
91
|
+
grpc_error_handle grpc_set_socket_ip_pktinfo_if_possible(int fd);
|
92
92
|
|
93
93
|
/* Tries to set IPV6_RECVPKTINFO if available on this platform.
|
94
94
|
If IPV6_RECVPKTINFO is not available, returns 1. */
|
95
|
-
|
95
|
+
grpc_error_handle grpc_set_socket_ipv6_recvpktinfo_if_possible(int fd);
|
96
96
|
|
97
97
|
/* Tries to set the socket's send buffer to given size. */
|
98
|
-
|
98
|
+
grpc_error_handle grpc_set_socket_sndbuf(int fd, int buffer_size_bytes);
|
99
99
|
|
100
100
|
/* Tries to set the socket's receive buffer to given size. */
|
101
|
-
|
101
|
+
grpc_error_handle grpc_set_socket_rcvbuf(int fd, int buffer_size_bytes);
|
102
102
|
|
103
103
|
/* Tries to set the socket using a grpc_socket_mutator */
|
104
|
-
|
104
|
+
grpc_error_handle grpc_set_socket_with_mutator(int fd,
|
105
|
+
grpc_socket_mutator* mutator);
|
105
106
|
|
106
107
|
/* Extracts the first socket mutator from args if any and applies on the fd. */
|
107
|
-
|
108
|
-
|
108
|
+
grpc_error_handle grpc_apply_socket_mutator_in_args(
|
109
|
+
int fd, const grpc_channel_args* args);
|
109
110
|
|
110
111
|
/* An enum to keep track of IPv4/IPv6 socket modes.
|
111
112
|
|
@@ -149,14 +150,13 @@ int grpc_set_socket_dualstack(int fd);
|
|
149
150
|
IPv4, so that bind() or connect() see the correct family.
|
150
151
|
Also, it's important to distinguish between DUALSTACK and IPV6 when
|
151
152
|
listening on the [::] wildcard address. */
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
int* newfd);
|
153
|
+
grpc_error_handle grpc_create_dualstack_socket(
|
154
|
+
const grpc_resolved_address* addr, int type, int protocol,
|
155
|
+
grpc_dualstack_mode* dsmode, int* newfd);
|
156
156
|
|
157
157
|
/* Same as grpc_create_dualstack_socket(), but use the given socket factory (if
|
158
158
|
non-null) to create the socket, rather than calling socket() directly. */
|
159
|
-
|
159
|
+
grpc_error_handle grpc_create_dualstack_socket_using_factory(
|
160
160
|
grpc_socket_factory* factory, const grpc_resolved_address* addr, int type,
|
161
161
|
int protocol, grpc_dualstack_mode* dsmode, int* newfd);
|
162
162
|
|
@@ -33,6 +33,7 @@
|
|
33
33
|
|
34
34
|
#include <netinet/in.h>
|
35
35
|
|
36
|
+
#include "src/core/lib/address_utils/sockaddr_utils.h"
|
36
37
|
#include "src/core/lib/channel/channel_args.h"
|
37
38
|
#include "src/core/lib/gprpp/host_port.h"
|
38
39
|
#include "src/core/lib/iomgr/cfstream_handle.h"
|
@@ -40,7 +41,6 @@
|
|
40
41
|
#include "src/core/lib/iomgr/endpoint_cfstream.h"
|
41
42
|
#include "src/core/lib/iomgr/error.h"
|
42
43
|
#include "src/core/lib/iomgr/error_cfstream.h"
|
43
|
-
#include "src/core/lib/iomgr/sockaddr_utils.h"
|
44
44
|
#include "src/core/lib/iomgr/tcp_client.h"
|
45
45
|
#include "src/core/lib/iomgr/timer.h"
|
46
46
|
|
@@ -78,7 +78,7 @@ static void CFStreamConnectCleanup(CFStreamConnect* connect) {
|
|
78
78
|
delete connect;
|
79
79
|
}
|
80
80
|
|
81
|
-
static void OnAlarm(void* arg,
|
81
|
+
static void OnAlarm(void* arg, grpc_error_handle error) {
|
82
82
|
CFStreamConnect* connect = static_cast<CFStreamConnect*>(arg);
|
83
83
|
if (grpc_tcp_trace.enabled()) {
|
84
84
|
gpr_log(GPR_DEBUG, "CLIENT_CONNECT :%p OnAlarm, error:%p", connect, error);
|
@@ -93,13 +93,13 @@ static void OnAlarm(void* arg, grpc_error* error) {
|
|
93
93
|
if (done) {
|
94
94
|
CFStreamConnectCleanup(connect);
|
95
95
|
} else {
|
96
|
-
|
96
|
+
grpc_error_handle error =
|
97
97
|
GRPC_ERROR_CREATE_FROM_STATIC_STRING("connect() timed out");
|
98
98
|
grpc_core::ExecCtx::Run(DEBUG_LOCATION, closure, error);
|
99
99
|
}
|
100
100
|
}
|
101
101
|
|
102
|
-
static void OnOpen(void* arg,
|
102
|
+
static void OnOpen(void* arg, grpc_error_handle error) {
|
103
103
|
CFStreamConnect* connect = static_cast<CFStreamConnect*>(arg);
|
104
104
|
if (grpc_tcp_trace.enabled()) {
|
105
105
|
gpr_log(GPR_DEBUG, "CLIENT_CONNECT :%p OnOpen, error:%p", connect, error);
|
@@ -25,9 +25,9 @@
|
|
25
25
|
#include <grpc/support/alloc.h>
|
26
26
|
#include <grpc/support/log.h>
|
27
27
|
|
28
|
+
#include "src/core/lib/address_utils/sockaddr_utils.h"
|
28
29
|
#include "src/core/lib/iomgr/error.h"
|
29
30
|
#include "src/core/lib/iomgr/iomgr_custom.h"
|
30
|
-
#include "src/core/lib/iomgr/sockaddr_utils.h"
|
31
31
|
#include "src/core/lib/iomgr/tcp_client.h"
|
32
32
|
#include "src/core/lib/iomgr/tcp_custom.h"
|
33
33
|
#include "src/core/lib/iomgr/timer.h"
|
@@ -59,14 +59,13 @@ static void custom_tcp_connect_cleanup(grpc_custom_tcp_connect* connect) {
|
|
59
59
|
|
60
60
|
static void custom_close_callback(grpc_custom_socket* /*socket*/) {}
|
61
61
|
|
62
|
-
static void on_alarm(void* acp,
|
62
|
+
static void on_alarm(void* acp, grpc_error_handle error) {
|
63
63
|
int done;
|
64
64
|
grpc_custom_socket* socket = static_cast<grpc_custom_socket*>(acp);
|
65
65
|
grpc_custom_tcp_connect* connect = socket->connector;
|
66
66
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
|
67
|
-
const char* str = grpc_error_string(error);
|
68
67
|
gpr_log(GPR_INFO, "CLIENT_CONNECT: %s: on_alarm: error=%s",
|
69
|
-
connect->addr_name.c_str(),
|
68
|
+
connect->addr_name.c_str(), grpc_error_std_string(error).c_str());
|
70
69
|
}
|
71
70
|
if (error == GRPC_ERROR_NONE) {
|
72
71
|
/* error == NONE implies that the timer ran out, and wasn't cancelled. If
|
@@ -81,7 +80,7 @@ static void on_alarm(void* acp, grpc_error* error) {
|
|
81
80
|
}
|
82
81
|
|
83
82
|
static void custom_connect_callback_internal(grpc_custom_socket* socket,
|
84
|
-
|
83
|
+
grpc_error_handle error) {
|
85
84
|
grpc_custom_tcp_connect* connect = socket->connector;
|
86
85
|
int done;
|
87
86
|
grpc_closure* closure = connect->closure;
|
@@ -99,7 +98,7 @@ static void custom_connect_callback_internal(grpc_custom_socket* socket,
|
|
99
98
|
}
|
100
99
|
|
101
100
|
static void custom_connect_callback(grpc_custom_socket* socket,
|
102
|
-
|
101
|
+
grpc_error_handle error) {
|
103
102
|
grpc_core::ApplicationCallbackExecCtx callback_exec_ctx;
|
104
103
|
if (grpc_core::ExecCtx::Get() == nullptr) {
|
105
104
|
/* If we are being run on a thread which does not have an exec_ctx created
|
@@ -35,12 +35,12 @@
|
|
35
35
|
#include <grpc/support/log.h>
|
36
36
|
#include <grpc/support/time.h>
|
37
37
|
|
38
|
+
#include "src/core/lib/address_utils/sockaddr_utils.h"
|
38
39
|
#include "src/core/lib/channel/channel_args.h"
|
39
40
|
#include "src/core/lib/gpr/string.h"
|
40
41
|
#include "src/core/lib/iomgr/ev_posix.h"
|
41
42
|
#include "src/core/lib/iomgr/iomgr_internal.h"
|
42
43
|
#include "src/core/lib/iomgr/sockaddr.h"
|
43
|
-
#include "src/core/lib/iomgr/sockaddr_utils.h"
|
44
44
|
#include "src/core/lib/iomgr/socket_mutator.h"
|
45
45
|
#include "src/core/lib/iomgr/socket_utils_posix.h"
|
46
46
|
#include "src/core/lib/iomgr/tcp_posix.h"
|
@@ -64,9 +64,10 @@ struct async_connect {
|
|
64
64
|
grpc_channel_args* channel_args;
|
65
65
|
};
|
66
66
|
|
67
|
-
static
|
68
|
-
|
69
|
-
|
67
|
+
static grpc_error_handle prepare_socket(const grpc_resolved_address* addr,
|
68
|
+
int fd,
|
69
|
+
const grpc_channel_args* channel_args) {
|
70
|
+
grpc_error_handle err = GRPC_ERROR_NONE;
|
70
71
|
|
71
72
|
GPR_ASSERT(fd >= 0);
|
72
73
|
|
@@ -99,13 +100,12 @@ done:
|
|
99
100
|
return err;
|
100
101
|
}
|
101
102
|
|
102
|
-
static void tc_on_alarm(void* acp,
|
103
|
+
static void tc_on_alarm(void* acp, grpc_error_handle error) {
|
103
104
|
int done;
|
104
105
|
async_connect* ac = static_cast<async_connect*>(acp);
|
105
106
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
|
106
|
-
const char* str = grpc_error_string(error);
|
107
107
|
gpr_log(GPR_INFO, "CLIENT_CONNECT: %s: on_alarm: error=%s",
|
108
|
-
ac->addr_str.c_str(),
|
108
|
+
ac->addr_str.c_str(), grpc_error_std_string(error).c_str());
|
109
109
|
}
|
110
110
|
gpr_mu_lock(&ac->mu);
|
111
111
|
if (ac->fd != nullptr) {
|
@@ -126,7 +126,7 @@ grpc_endpoint* grpc_tcp_client_create_from_fd(
|
|
126
126
|
return grpc_tcp_create(fd, channel_args, addr_str);
|
127
127
|
}
|
128
128
|
|
129
|
-
static void on_writable(void* acp,
|
129
|
+
static void on_writable(void* acp, grpc_error_handle error) {
|
130
130
|
async_connect* ac = static_cast<async_connect*>(acp);
|
131
131
|
int so_error = 0;
|
132
132
|
socklen_t so_error_size;
|
@@ -139,9 +139,8 @@ static void on_writable(void* acp, grpc_error* error) {
|
|
139
139
|
GRPC_ERROR_REF(error);
|
140
140
|
|
141
141
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_tcp_trace)) {
|
142
|
-
const char* str = grpc_error_string(error);
|
143
142
|
gpr_log(GPR_INFO, "CLIENT_CONNECT: %s: on_writable: error=%s",
|
144
|
-
ac->addr_str.c_str(),
|
143
|
+
ac->addr_str.c_str(), grpc_error_std_string(error).c_str());
|
145
144
|
}
|
146
145
|
|
147
146
|
gpr_mu_lock(&ac->mu);
|
@@ -242,12 +241,11 @@ finish:
|
|
242
241
|
grpc_core::ExecCtx::Run(DEBUG_LOCATION, closure, error);
|
243
242
|
}
|
244
243
|
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
int* fd) {
|
244
|
+
grpc_error_handle grpc_tcp_client_prepare_fd(
|
245
|
+
const grpc_channel_args* channel_args, const grpc_resolved_address* addr,
|
246
|
+
grpc_resolved_address* mapped_addr, int* fd) {
|
249
247
|
grpc_dualstack_mode dsmode;
|
250
|
-
|
248
|
+
grpc_error_handle error;
|
251
249
|
*fd = -1;
|
252
250
|
/* Use dualstack sockets where available. Set mapped to v6 or v4 mapped to
|
253
251
|
v6. */
|
@@ -293,7 +291,7 @@ void grpc_tcp_client_create_from_prepared_fd(
|
|
293
291
|
return;
|
294
292
|
}
|
295
293
|
if (errno != EWOULDBLOCK && errno != EINPROGRESS) {
|
296
|
-
|
294
|
+
grpc_error_handle error = GRPC_OS_ERROR(errno, "connect");
|
297
295
|
error = grpc_error_set_str(
|
298
296
|
error, GRPC_ERROR_STR_TARGET_ADDRESS,
|
299
297
|
grpc_slice_from_cpp_string(grpc_sockaddr_to_uri(addr)));
|
@@ -335,7 +333,7 @@ static void tcp_connect(grpc_closure* closure, grpc_endpoint** ep,
|
|
335
333
|
grpc_millis deadline) {
|
336
334
|
grpc_resolved_address mapped_addr;
|
337
335
|
int fd = -1;
|
338
|
-
|
336
|
+
grpc_error_handle error;
|
339
337
|
*ep = nullptr;
|
340
338
|
if ((error = grpc_tcp_client_prepare_fd(channel_args, addr, &mapped_addr,
|
341
339
|
&fd)) != GRPC_ERROR_NONE) {
|