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
data/src/core/lib/surface/call.h
CHANGED
@@ -55,8 +55,8 @@ typedef struct grpc_call_create_args {
|
|
55
55
|
/* Create a new call based on \a args.
|
56
56
|
Regardless of success or failure, always returns a valid new call into *call
|
57
57
|
*/
|
58
|
-
|
59
|
-
|
58
|
+
grpc_error_handle grpc_call_create(const grpc_call_create_args* args,
|
59
|
+
grpc_call** call);
|
60
60
|
|
61
61
|
void grpc_call_set_completion_queue(grpc_call* call, grpc_completion_queue* cq);
|
62
62
|
|
@@ -54,11 +54,11 @@
|
|
54
54
|
* (OK, Cancelled, Unknown). */
|
55
55
|
#define NUM_CACHED_STATUS_ELEMS 3
|
56
56
|
|
57
|
-
static void destroy_channel(void* arg,
|
57
|
+
static void destroy_channel(void* arg, grpc_error_handle error);
|
58
58
|
|
59
59
|
grpc_channel* grpc_channel_create_with_builder(
|
60
60
|
grpc_channel_stack_builder* builder,
|
61
|
-
grpc_channel_stack_type channel_stack_type,
|
61
|
+
grpc_channel_stack_type channel_stack_type, grpc_error_handle* error) {
|
62
62
|
char* target = gpr_strdup(grpc_channel_stack_builder_get_target(builder));
|
63
63
|
grpc_channel_args* args = grpc_channel_args_copy(
|
64
64
|
grpc_channel_stack_builder_get_channel_arguments(builder));
|
@@ -70,12 +70,12 @@ grpc_channel* grpc_channel_create_with_builder(
|
|
70
70
|
} else {
|
71
71
|
GRPC_STATS_INC_CLIENT_CHANNELS_CREATED();
|
72
72
|
}
|
73
|
-
|
73
|
+
grpc_error_handle builder_error = grpc_channel_stack_builder_finish(
|
74
74
|
builder, sizeof(grpc_channel), 1, destroy_channel, nullptr,
|
75
75
|
reinterpret_cast<void**>(&channel));
|
76
76
|
if (builder_error != GRPC_ERROR_NONE) {
|
77
77
|
gpr_log(GPR_ERROR, "channel stack builder failed: %s",
|
78
|
-
|
78
|
+
grpc_error_std_string(builder_error).c_str());
|
79
79
|
GPR_ASSERT(channel == nullptr);
|
80
80
|
if (error != nullptr) {
|
81
81
|
*error = builder_error;
|
@@ -225,7 +225,7 @@ grpc_channel* grpc_channel_create(const char* target,
|
|
225
225
|
grpc_channel_stack_type channel_stack_type,
|
226
226
|
grpc_transport* optional_transport,
|
227
227
|
grpc_resource_user* resource_user,
|
228
|
-
|
228
|
+
grpc_error_handle* error) {
|
229
229
|
// We need to make sure that grpc_shutdown() does not shut things down
|
230
230
|
// until after the channel is destroyed. However, the channel may not
|
231
231
|
// actually be destroyed by the time grpc_channel_destroy() returns,
|
@@ -497,7 +497,7 @@ grpc_call* grpc_channel_create_registered_call(
|
|
497
497
|
return call;
|
498
498
|
}
|
499
499
|
|
500
|
-
static void destroy_channel(void* arg,
|
500
|
+
static void destroy_channel(void* arg, grpc_error_handle /*error*/) {
|
501
501
|
grpc_channel* channel = static_cast<grpc_channel*>(arg);
|
502
502
|
if (channel->channelz_node != nullptr) {
|
503
503
|
channel->channelz_node->AddTraceEvent(
|
@@ -35,7 +35,7 @@ grpc_channel* grpc_channel_create(const char* target,
|
|
35
35
|
grpc_channel_stack_type channel_stack_type,
|
36
36
|
grpc_transport* optional_transport,
|
37
37
|
grpc_resource_user* resource_user = nullptr,
|
38
|
-
|
38
|
+
grpc_error_handle* error = nullptr);
|
39
39
|
|
40
40
|
/** The same as grpc_channel_destroy, but doesn't create an ExecCtx, and so
|
41
41
|
* is safe to use from within core. */
|
@@ -43,7 +43,8 @@ void grpc_channel_destroy_internal(grpc_channel* channel);
|
|
43
43
|
|
44
44
|
grpc_channel* grpc_channel_create_with_builder(
|
45
45
|
grpc_channel_stack_builder* builder,
|
46
|
-
grpc_channel_stack_type channel_stack_type,
|
46
|
+
grpc_channel_stack_type channel_stack_type,
|
47
|
+
grpc_error_handle* error = nullptr);
|
47
48
|
|
48
49
|
/** Create a call given a grpc_channel, in order to call \a method.
|
49
50
|
Progress is tied to activity on \a pollset_set. The returned call object is
|
@@ -94,9 +95,9 @@ struct CallRegistrationTable {
|
|
94
95
|
// The map key should be owned strings rather than unowned char*'s to
|
95
96
|
// guarantee that it outlives calls on the core channel (which may outlast the
|
96
97
|
// C++ or other wrapped language Channel that registered these calls).
|
97
|
-
std::map<std::pair<std::string, std::string>, RegisteredCall>
|
98
|
-
|
99
|
-
int method_registration_attempts
|
98
|
+
std::map<std::pair<std::string, std::string>, RegisteredCall> map
|
99
|
+
ABSL_GUARDED_BY(mu);
|
100
|
+
int method_registration_attempts ABSL_GUARDED_BY(mu) = 0;
|
100
101
|
};
|
101
102
|
|
102
103
|
} // namespace grpc_core
|
@@ -38,7 +38,7 @@ static void ping_destroy(void* arg, grpc_cq_completion* /*storage*/) {
|
|
38
38
|
gpr_free(arg);
|
39
39
|
}
|
40
40
|
|
41
|
-
static void ping_done(void* arg,
|
41
|
+
static void ping_done(void* arg, grpc_error_handle error) {
|
42
42
|
ping_result* pr = static_cast<ping_result*>(arg);
|
43
43
|
grpc_cq_end_op(pr->cq, pr->tag, GRPC_ERROR_REF(error), ping_destroy, pr,
|
44
44
|
&pr->completion_storage);
|
@@ -70,10 +70,10 @@ struct cq_poller_vtable {
|
|
70
70
|
bool can_listen;
|
71
71
|
size_t (*size)(void);
|
72
72
|
void (*init)(grpc_pollset* pollset, gpr_mu** mu);
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
73
|
+
grpc_error_handle (*kick)(grpc_pollset* pollset,
|
74
|
+
grpc_pollset_worker* specific_worker);
|
75
|
+
grpc_error_handle (*work)(grpc_pollset* pollset, grpc_pollset_worker** worker,
|
76
|
+
grpc_millis deadline);
|
77
77
|
void (*shutdown)(grpc_pollset* pollset, grpc_closure* closure);
|
78
78
|
void (*destroy)(grpc_pollset* pollset);
|
79
79
|
};
|
@@ -103,9 +103,9 @@ void non_polling_poller_destroy(grpc_pollset* pollset) {
|
|
103
103
|
gpr_mu_destroy(&npp->mu);
|
104
104
|
}
|
105
105
|
|
106
|
-
|
107
|
-
|
108
|
-
|
106
|
+
grpc_error_handle non_polling_poller_work(grpc_pollset* pollset,
|
107
|
+
grpc_pollset_worker** worker,
|
108
|
+
grpc_millis deadline) {
|
109
109
|
non_polling_poller* npp = reinterpret_cast<non_polling_poller*>(pollset);
|
110
110
|
if (npp->shutdown) return GRPC_ERROR_NONE;
|
111
111
|
if (npp->kicked_without_poller) {
|
@@ -145,8 +145,8 @@ grpc_error* non_polling_poller_work(grpc_pollset* pollset,
|
|
145
145
|
return GRPC_ERROR_NONE;
|
146
146
|
}
|
147
147
|
|
148
|
-
|
149
|
-
|
148
|
+
grpc_error_handle non_polling_poller_kick(
|
149
|
+
grpc_pollset* pollset, grpc_pollset_worker* specific_worker) {
|
150
150
|
non_polling_poller* p = reinterpret_cast<non_polling_poller*>(pollset);
|
151
151
|
if (specific_worker == nullptr) {
|
152
152
|
specific_worker = reinterpret_cast<grpc_pollset_worker*>(p->root);
|
@@ -202,7 +202,7 @@ struct cq_vtable {
|
|
202
202
|
void (*shutdown)(grpc_completion_queue* cq);
|
203
203
|
void (*destroy)(void* data);
|
204
204
|
bool (*begin_op)(grpc_completion_queue* cq, void* tag);
|
205
|
-
void (*end_op)(grpc_completion_queue* cq, void* tag,
|
205
|
+
void (*end_op)(grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
206
206
|
void (*done)(void* done_arg, grpc_cq_completion* storage),
|
207
207
|
void* done_arg, grpc_cq_completion* storage, bool internal);
|
208
208
|
grpc_event (*next)(grpc_completion_queue* cq, gpr_timespec deadline,
|
@@ -376,17 +376,17 @@ static bool cq_begin_op_for_callback(grpc_completion_queue* cq, void* tag);
|
|
376
376
|
// safe to free up that storage. The storage MUST NOT be freed until the
|
377
377
|
// done callback is invoked.
|
378
378
|
static void cq_end_op_for_next(
|
379
|
-
grpc_completion_queue* cq, void* tag,
|
379
|
+
grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
380
380
|
void (*done)(void* done_arg, grpc_cq_completion* storage), void* done_arg,
|
381
381
|
grpc_cq_completion* storage, bool internal);
|
382
382
|
|
383
383
|
static void cq_end_op_for_pluck(
|
384
|
-
grpc_completion_queue* cq, void* tag,
|
384
|
+
grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
385
385
|
void (*done)(void* done_arg, grpc_cq_completion* storage), void* done_arg,
|
386
386
|
grpc_cq_completion* storage, bool internal);
|
387
387
|
|
388
388
|
static void cq_end_op_for_callback(
|
389
|
-
grpc_completion_queue* cq, void* tag,
|
389
|
+
grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
390
390
|
void (*done)(void* done_arg, grpc_cq_completion* storage), void* done_arg,
|
391
391
|
grpc_cq_completion* storage, bool internal);
|
392
392
|
|
@@ -439,7 +439,7 @@ grpc_core::TraceFlag grpc_cq_pluck_trace(false, "queue_pluck");
|
|
439
439
|
} \
|
440
440
|
} while (0)
|
441
441
|
|
442
|
-
static void on_pollset_shutdown_done(void* arg,
|
442
|
+
static void on_pollset_shutdown_done(void* arg, grpc_error_handle error);
|
443
443
|
|
444
444
|
void grpc_cq_global_init() {
|
445
445
|
gpr_tls_init(&g_cached_event);
|
@@ -604,7 +604,7 @@ void grpc_cq_internal_ref(grpc_completion_queue* cq) {
|
|
604
604
|
cq->owning_refs.Ref(debug_location, reason);
|
605
605
|
}
|
606
606
|
|
607
|
-
static void on_pollset_shutdown_done(void* arg,
|
607
|
+
static void on_pollset_shutdown_done(void* arg, grpc_error_handle /*error*/) {
|
608
608
|
grpc_completion_queue* cq = static_cast<grpc_completion_queue*>(arg);
|
609
609
|
GRPC_CQ_INTERNAL_UNREF(cq, "pollset_destroy");
|
610
610
|
}
|
@@ -690,7 +690,7 @@ bool grpc_cq_begin_op(grpc_completion_queue* cq, void* tag) {
|
|
690
690
|
* completion
|
691
691
|
* type of GRPC_CQ_NEXT) */
|
692
692
|
static void cq_end_op_for_next(
|
693
|
-
grpc_completion_queue* cq, void* tag,
|
693
|
+
grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
694
694
|
void (*done)(void* done_arg, grpc_cq_completion* storage), void* done_arg,
|
695
695
|
grpc_cq_completion* storage, bool /*internal*/) {
|
696
696
|
GPR_TIMER_SCOPE("cq_end_op_for_next", 0);
|
@@ -698,14 +698,15 @@ static void cq_end_op_for_next(
|
|
698
698
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_api_trace) ||
|
699
699
|
(GRPC_TRACE_FLAG_ENABLED(grpc_trace_operation_failures) &&
|
700
700
|
error != GRPC_ERROR_NONE)) {
|
701
|
-
|
701
|
+
std::string errmsg = grpc_error_std_string(error);
|
702
702
|
GRPC_API_TRACE(
|
703
703
|
"cq_end_op_for_next(cq=%p, tag=%p, error=%s, "
|
704
704
|
"done=%p, done_arg=%p, storage=%p)",
|
705
|
-
6, (cq, tag, errmsg, done, done_arg, storage));
|
705
|
+
6, (cq, tag, errmsg.c_str(), done, done_arg, storage));
|
706
706
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_operation_failures) &&
|
707
707
|
error != GRPC_ERROR_NONE) {
|
708
|
-
gpr_log(
|
708
|
+
gpr_log(GPR_INFO, "Operation failed: tag=%p, error=%s", tag,
|
709
|
+
errmsg.c_str());
|
709
710
|
}
|
710
711
|
}
|
711
712
|
cq_next_data* cqd = static_cast<cq_next_data*> DATA_FROM_CQ(cq);
|
@@ -736,13 +737,13 @@ static void cq_end_op_for_next(
|
|
736
737
|
/* Only kick if this is the first item queued */
|
737
738
|
if (is_first) {
|
738
739
|
gpr_mu_lock(cq->mu);
|
739
|
-
|
740
|
+
grpc_error_handle kick_error =
|
740
741
|
cq->poller_vtable->kick(POLLSET_FROM_CQ(cq), nullptr);
|
741
742
|
gpr_mu_unlock(cq->mu);
|
742
743
|
|
743
744
|
if (kick_error != GRPC_ERROR_NONE) {
|
744
|
-
|
745
|
-
|
745
|
+
gpr_log(GPR_ERROR, "Kick failed: %s",
|
746
|
+
grpc_error_std_string(kick_error).c_str());
|
746
747
|
GRPC_ERROR_UNREF(kick_error);
|
747
748
|
}
|
748
749
|
}
|
@@ -771,7 +772,7 @@ static void cq_end_op_for_next(
|
|
771
772
|
* completion
|
772
773
|
* type of GRPC_CQ_PLUCK) */
|
773
774
|
static void cq_end_op_for_pluck(
|
774
|
-
grpc_completion_queue* cq, void* tag,
|
775
|
+
grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
775
776
|
void (*done)(void* done_arg, grpc_cq_completion* storage), void* done_arg,
|
776
777
|
grpc_cq_completion* storage, bool /*internal*/) {
|
777
778
|
GPR_TIMER_SCOPE("cq_end_op_for_pluck", 0);
|
@@ -782,14 +783,15 @@ static void cq_end_op_for_pluck(
|
|
782
783
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_api_trace) ||
|
783
784
|
(GRPC_TRACE_FLAG_ENABLED(grpc_trace_operation_failures) &&
|
784
785
|
error != GRPC_ERROR_NONE)) {
|
785
|
-
|
786
|
+
std::string errmsg = grpc_error_std_string(error).c_str();
|
786
787
|
GRPC_API_TRACE(
|
787
788
|
"cq_end_op_for_pluck(cq=%p, tag=%p, error=%s, "
|
788
789
|
"done=%p, done_arg=%p, storage=%p)",
|
789
|
-
6, (cq, tag, errmsg, done, done_arg, storage));
|
790
|
+
6, (cq, tag, errmsg.c_str(), done, done_arg, storage));
|
790
791
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_operation_failures) &&
|
791
792
|
error != GRPC_ERROR_NONE) {
|
792
|
-
gpr_log(GPR_ERROR, "Operation failed: tag=%p, error=%s", tag,
|
793
|
+
gpr_log(GPR_ERROR, "Operation failed: tag=%p, error=%s", tag,
|
794
|
+
errmsg.c_str());
|
793
795
|
}
|
794
796
|
}
|
795
797
|
|
@@ -820,15 +822,12 @@ static void cq_end_op_for_pluck(
|
|
820
822
|
}
|
821
823
|
}
|
822
824
|
|
823
|
-
|
825
|
+
grpc_error_handle kick_error =
|
824
826
|
cq->poller_vtable->kick(POLLSET_FROM_CQ(cq), pluck_worker);
|
825
|
-
|
826
827
|
gpr_mu_unlock(cq->mu);
|
827
|
-
|
828
828
|
if (kick_error != GRPC_ERROR_NONE) {
|
829
|
-
|
830
|
-
|
831
|
-
|
829
|
+
gpr_log(GPR_ERROR, "Kick failed: %s",
|
830
|
+
grpc_error_std_string(kick_error).c_str());
|
832
831
|
GRPC_ERROR_UNREF(kick_error);
|
833
832
|
}
|
834
833
|
}
|
@@ -836,14 +835,14 @@ static void cq_end_op_for_pluck(
|
|
836
835
|
GRPC_ERROR_UNREF(error);
|
837
836
|
}
|
838
837
|
|
839
|
-
static void functor_callback(void* arg,
|
838
|
+
static void functor_callback(void* arg, grpc_error_handle error) {
|
840
839
|
auto* functor = static_cast<grpc_experimental_completion_queue_functor*>(arg);
|
841
840
|
functor->functor_run(functor, error == GRPC_ERROR_NONE);
|
842
841
|
}
|
843
842
|
|
844
843
|
/* Complete an event on a completion queue of type GRPC_CQ_CALLBACK */
|
845
844
|
static void cq_end_op_for_callback(
|
846
|
-
grpc_completion_queue* cq, void* tag,
|
845
|
+
grpc_completion_queue* cq, void* tag, grpc_error_handle error,
|
847
846
|
void (*done)(void* done_arg, grpc_cq_completion* storage), void* done_arg,
|
848
847
|
grpc_cq_completion* storage, bool internal) {
|
849
848
|
GPR_TIMER_SCOPE("cq_end_op_for_callback", 0);
|
@@ -853,14 +852,15 @@ static void cq_end_op_for_callback(
|
|
853
852
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_api_trace) ||
|
854
853
|
(GRPC_TRACE_FLAG_ENABLED(grpc_trace_operation_failures) &&
|
855
854
|
error != GRPC_ERROR_NONE)) {
|
856
|
-
|
855
|
+
std::string errmsg = grpc_error_std_string(error);
|
857
856
|
GRPC_API_TRACE(
|
858
857
|
"cq_end_op_for_callback(cq=%p, tag=%p, error=%s, "
|
859
858
|
"done=%p, done_arg=%p, storage=%p)",
|
860
|
-
6, (cq, tag, errmsg, done, done_arg, storage));
|
859
|
+
6, (cq, tag, errmsg.c_str(), done, done_arg, storage));
|
861
860
|
if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_operation_failures) &&
|
862
861
|
error != GRPC_ERROR_NONE) {
|
863
|
-
gpr_log(GPR_ERROR, "Operation failed: tag=%p, error=%s", tag,
|
862
|
+
gpr_log(GPR_ERROR, "Operation failed: tag=%p, error=%s", tag,
|
863
|
+
errmsg.c_str());
|
864
864
|
}
|
865
865
|
}
|
866
866
|
|
@@ -896,7 +896,8 @@ static void cq_end_op_for_callback(
|
|
896
896
|
GRPC_CLOSURE_CREATE(functor_callback, functor, nullptr), error);
|
897
897
|
}
|
898
898
|
|
899
|
-
void grpc_cq_end_op(grpc_completion_queue* cq, void* tag,
|
899
|
+
void grpc_cq_end_op(grpc_completion_queue* cq, void* tag,
|
900
|
+
grpc_error_handle error,
|
900
901
|
void (*done)(void* done_arg, grpc_cq_completion* storage),
|
901
902
|
void* done_arg, grpc_cq_completion* storage,
|
902
903
|
bool internal) {
|
@@ -1056,14 +1057,13 @@ static grpc_event cq_next(grpc_completion_queue* cq, gpr_timespec deadline,
|
|
1056
1057
|
/* The main polling work happens in grpc_pollset_work */
|
1057
1058
|
gpr_mu_lock(cq->mu);
|
1058
1059
|
cq->num_polls++;
|
1059
|
-
|
1060
|
-
|
1060
|
+
grpc_error_handle err = cq->poller_vtable->work(
|
1061
|
+
POLLSET_FROM_CQ(cq), nullptr, iteration_deadline);
|
1061
1062
|
gpr_mu_unlock(cq->mu);
|
1062
1063
|
|
1063
1064
|
if (err != GRPC_ERROR_NONE) {
|
1064
|
-
|
1065
|
-
|
1066
|
-
|
1065
|
+
gpr_log(GPR_ERROR, "Completion queue next failed: %s",
|
1066
|
+
grpc_error_std_string(err).c_str());
|
1067
1067
|
GRPC_ERROR_UNREF(err);
|
1068
1068
|
ret.type = GRPC_QUEUE_TIMEOUT;
|
1069
1069
|
ret.success = 0;
|
@@ -1299,14 +1299,13 @@ static grpc_event cq_pluck(grpc_completion_queue* cq, void* tag,
|
|
1299
1299
|
break;
|
1300
1300
|
}
|
1301
1301
|
cq->num_polls++;
|
1302
|
-
|
1302
|
+
grpc_error_handle err =
|
1303
1303
|
cq->poller_vtable->work(POLLSET_FROM_CQ(cq), &worker, deadline_millis);
|
1304
1304
|
if (err != GRPC_ERROR_NONE) {
|
1305
1305
|
del_plucker(cq, tag, &worker);
|
1306
1306
|
gpr_mu_unlock(cq->mu);
|
1307
|
-
|
1308
|
-
|
1309
|
-
|
1307
|
+
gpr_log(GPR_ERROR, "Completion queue pluck failed: %s",
|
1308
|
+
grpc_error_std_string(err).c_str());
|
1310
1309
|
GRPC_ERROR_UNREF(err);
|
1311
1310
|
ret.type = GRPC_QUEUE_TIMEOUT;
|
1312
1311
|
ret.success = 0;
|
@@ -77,7 +77,8 @@ bool grpc_cq_begin_op(grpc_completion_queue* cq, void* tag);
|
|
77
77
|
|
78
78
|
/* Queue a GRPC_OP_COMPLETED operation; tag must correspond to the tag passed to
|
79
79
|
grpc_cq_begin_op */
|
80
|
-
void grpc_cq_end_op(grpc_completion_queue* cq, void* tag,
|
80
|
+
void grpc_cq_end_op(grpc_completion_queue* cq, void* tag,
|
81
|
+
grpc_error_handle error,
|
81
82
|
void (*done)(void* done_arg, grpc_cq_completion* storage),
|
82
83
|
void* done_arg, grpc_cq_completion* storage,
|
83
84
|
bool internal = false);
|
@@ -35,15 +35,23 @@
|
|
35
35
|
#include "src/core/lib/transport/connectivity_state.h"
|
36
36
|
#include "src/core/lib/transport/static_metadata.h"
|
37
37
|
|
38
|
+
#define GRPC_ARG_LAME_FILTER_ERROR "grpc.lame_filter_error"
|
39
|
+
|
38
40
|
namespace grpc_core {
|
39
41
|
|
40
42
|
namespace {
|
41
43
|
|
42
44
|
struct ChannelData {
|
43
|
-
ChannelData(
|
45
|
+
explicit ChannelData(grpc_channel_element_args* args)
|
46
|
+
: state_tracker("lame_channel", GRPC_CHANNEL_SHUTDOWN) {
|
47
|
+
grpc_error_handle err = grpc_channel_args_find_pointer<grpc_error>(
|
48
|
+
args->channel_args, GRPC_ARG_LAME_FILTER_ERROR);
|
49
|
+
if (err != nullptr) error = GRPC_ERROR_REF(err);
|
50
|
+
}
|
51
|
+
|
44
52
|
~ChannelData() { GRPC_ERROR_UNREF(error); }
|
45
53
|
|
46
|
-
|
54
|
+
grpc_error_handle error = GRPC_ERROR_NONE;
|
47
55
|
Mutex mu;
|
48
56
|
ConnectivityStateTracker state_tracker;
|
49
57
|
};
|
@@ -90,8 +98,8 @@ static void lame_start_transport_op(grpc_channel_element* elem,
|
|
90
98
|
}
|
91
99
|
}
|
92
100
|
|
93
|
-
static
|
94
|
-
|
101
|
+
static grpc_error_handle lame_init_call_elem(
|
102
|
+
grpc_call_element* elem, const grpc_call_element_args* args) {
|
95
103
|
CallData* calld = static_cast<CallData*>(elem->call_data);
|
96
104
|
calld->call_combiner = args->call_combiner;
|
97
105
|
return GRPC_ERROR_NONE;
|
@@ -103,11 +111,9 @@ static void lame_destroy_call_elem(grpc_call_element* /*elem*/,
|
|
103
111
|
ExecCtx::Run(DEBUG_LOCATION, then_schedule_closure, GRPC_ERROR_NONE);
|
104
112
|
}
|
105
113
|
|
106
|
-
static
|
107
|
-
|
108
|
-
|
109
|
-
GPR_ASSERT(args->is_last);
|
110
|
-
new (elem->channel_data) ChannelData;
|
114
|
+
static grpc_error_handle lame_init_channel_elem(
|
115
|
+
grpc_channel_element* elem, grpc_channel_element_args* args) {
|
116
|
+
new (elem->channel_data) ChannelData(args);
|
111
117
|
return GRPC_ERROR_NONE;
|
112
118
|
}
|
113
119
|
|
@@ -116,12 +122,25 @@ static void lame_destroy_channel_elem(grpc_channel_element* elem) {
|
|
116
122
|
chand->~ChannelData();
|
117
123
|
}
|
118
124
|
|
125
|
+
// Channel arg vtable for a grpc_error_handle.
|
126
|
+
void* ErrorCopy(void* p) {
|
127
|
+
grpc_error_handle error = static_cast<grpc_error_handle>(p);
|
128
|
+
return GRPC_ERROR_REF(error);
|
129
|
+
}
|
130
|
+
void ErrorDestroy(void* p) {
|
131
|
+
grpc_error_handle error = static_cast<grpc_error_handle>(p);
|
132
|
+
GRPC_ERROR_UNREF(error);
|
133
|
+
}
|
134
|
+
int ErrorCompare(void* p, void* q) { return GPR_ICMP(p, q); }
|
135
|
+
const grpc_arg_pointer_vtable kLameFilterErrorArgVtable = {
|
136
|
+
ErrorCopy, ErrorDestroy, ErrorCompare};
|
137
|
+
|
119
138
|
} // namespace
|
120
139
|
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
140
|
+
grpc_arg MakeLameClientErrorArg(grpc_error_handle error) {
|
141
|
+
return grpc_channel_arg_pointer_create(
|
142
|
+
const_cast<char*>(GRPC_ARG_LAME_FILTER_ERROR), error,
|
143
|
+
&kLameFilterErrorArgVtable);
|
125
144
|
}
|
126
145
|
|
127
146
|
} // namespace grpc_core
|
@@ -146,20 +165,20 @@ grpc_channel* grpc_lame_client_channel_create(const char* target,
|
|
146
165
|
grpc_status_code error_code,
|
147
166
|
const char* error_message) {
|
148
167
|
grpc_core::ExecCtx exec_ctx;
|
149
|
-
grpc_channel_element* elem;
|
150
|
-
grpc_channel* channel =
|
151
|
-
grpc_channel_create(target, nullptr, GRPC_CLIENT_LAME_CHANNEL, nullptr);
|
152
|
-
elem = grpc_channel_stack_element(grpc_channel_get_channel_stack(channel), 0);
|
153
168
|
GRPC_API_TRACE(
|
154
169
|
"grpc_lame_client_channel_create(target=%s, error_code=%d, "
|
155
170
|
"error_message=%s)",
|
156
171
|
3, (target, (int)error_code, error_message));
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
172
|
+
grpc_error_handle error = grpc_error_set_str(
|
173
|
+
grpc_error_set_int(
|
174
|
+
GRPC_ERROR_CREATE_FROM_STATIC_STRING("lame client channel"),
|
175
|
+
GRPC_ERROR_INT_GRPC_STATUS, error_code),
|
176
|
+
GRPC_ERROR_STR_GRPC_MESSAGE,
|
177
|
+
grpc_slice_from_static_string(error_message));
|
178
|
+
grpc_arg error_arg = grpc_core::MakeLameClientErrorArg(error);
|
179
|
+
grpc_channel_args args = {1, &error_arg};
|
180
|
+
grpc_channel* channel =
|
181
|
+
grpc_channel_create(target, &args, GRPC_CLIENT_LAME_CHANNEL, nullptr);
|
182
|
+
GRPC_ERROR_UNREF(error);
|
164
183
|
return channel;
|
165
184
|
}
|