grpc 1.50.0.pre1 → 1.51.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 +131 -42
- data/include/grpc/event_engine/event_engine.h +10 -3
- data/include/grpc/event_engine/slice_buffer.h +17 -0
- data/include/grpc/grpc.h +0 -10
- data/include/grpc/impl/codegen/grpc_types.h +1 -5
- data/include/grpc/impl/codegen/port_platform.h +0 -3
- data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +19 -13
- data/src/core/ext/filters/channel_idle/channel_idle_filter.h +1 -0
- data/src/core/ext/filters/client_channel/backup_poller.cc +3 -3
- data/src/core/ext/filters/client_channel/channel_connectivity.cc +7 -5
- data/src/core/ext/filters/client_channel/client_channel.cc +120 -140
- data/src/core/ext/filters/client_channel/client_channel.h +3 -4
- data/src/core/ext/filters/client_channel/client_channel_channelz.cc +0 -2
- data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
- data/src/core/ext/filters/client_channel/client_channel_service_config.cc +153 -0
- data/src/core/ext/filters/client_channel/{resolver_result_parsing.h → client_channel_service_config.h} +26 -23
- data/src/core/ext/filters/client_channel/connector.h +1 -1
- data/src/core/ext/filters/client_channel/dynamic_filters.cc +20 -47
- data/src/core/ext/filters/client_channel/dynamic_filters.h +7 -8
- data/src/core/ext/filters/client_channel/health/health_check_client.cc +3 -4
- data/src/core/ext/filters/client_channel/http_proxy.cc +0 -1
- data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +3 -4
- data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +5 -0
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +8 -7
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +35 -44
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -1
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +1 -3
- data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +3 -4
- data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +1 -1
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +41 -29
- data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +2 -2
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +9 -11
- data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +15 -12
- data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +8 -10
- data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +26 -27
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +7 -9
- data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +44 -26
- data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +17 -27
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.cc +42 -0
- data/src/core/ext/filters/client_channel/lb_policy/xds/{xds.h → xds_attributes.h} +15 -17
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +13 -7
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +48 -47
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +40 -126
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +364 -0
- data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +9 -9
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +23 -32
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +1 -2
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +22 -23
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +50 -52
- 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/native/dns_resolver.cc +2 -4
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +1 -3
- data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +34 -26
- data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +3 -4
- data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +4 -7
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +63 -46
- data/src/core/ext/filters/client_channel/retry_filter.cc +80 -102
- data/src/core/ext/filters/client_channel/retry_service_config.cc +192 -234
- data/src/core/ext/filters/client_channel/retry_service_config.h +20 -23
- data/src/core/ext/filters/client_channel/retry_throttle.cc +8 -8
- data/src/core/ext/filters/client_channel/retry_throttle.h +8 -7
- data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -2
- data/src/core/ext/filters/client_channel/subchannel.cc +21 -25
- data/src/core/ext/filters/client_channel/subchannel.h +2 -2
- data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +11 -12
- data/src/core/ext/filters/deadline/deadline_filter.cc +13 -14
- data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +1 -1
- data/src/core/ext/filters/fault_injection/fault_injection_filter.h +0 -4
- data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +118 -0
- data/src/core/ext/filters/fault_injection/{service_config_parser.h → fault_injection_service_config_parser.h} +20 -12
- data/src/core/ext/filters/http/client/http_client_filter.cc +16 -16
- data/src/core/ext/filters/http/client_authority_filter.cc +1 -1
- data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +13 -13
- data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +34 -34
- data/src/core/ext/filters/http/server/http_server_filter.cc +26 -25
- data/src/core/ext/filters/message_size/message_size_filter.cc +86 -117
- data/src/core/ext/filters/message_size/message_size_filter.h +22 -15
- data/src/core/ext/filters/rbac/rbac_filter.cc +12 -12
- data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +728 -530
- data/src/core/ext/filters/rbac/rbac_service_config_parser.h +4 -3
- data/src/core/ext/filters/server_config_selector/server_config_selector.h +1 -1
- data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +6 -7
- data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +17 -21
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +57 -72
- data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +5 -5
- data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -1
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +212 -253
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +42 -11
- data/src/core/ext/transport/chttp2/transport/flow_control.h +4 -3
- data/src/core/ext/transport/chttp2/transport/frame_data.cc +16 -15
- data/src/core/ext/transport/chttp2/transport/frame_data.h +1 -1
- data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +13 -13
- data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -3
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +10 -7
- data/src/core/ext/transport/chttp2/transport/frame_settings.cc +15 -17
- data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +5 -4
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +5 -6
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +1 -1
- data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -1
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +31 -39
- data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +7 -6
- data/src/core/ext/transport/chttp2/transport/internal.h +24 -8
- data/src/core/ext/transport/chttp2/transport/parsing.cc +51 -52
- data/src/core/ext/transport/chttp2/transport/varint.cc +2 -3
- data/src/core/ext/transport/chttp2/transport/varint.h +11 -8
- data/src/core/ext/transport/chttp2/transport/writing.cc +16 -16
- data/src/core/ext/transport/inproc/inproc_transport.cc +97 -115
- data/src/core/ext/xds/certificate_provider_store.cc +4 -4
- data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +4 -7
- data/src/core/ext/xds/xds_api.cc +15 -68
- data/src/core/ext/xds/xds_api.h +3 -7
- data/src/core/ext/xds/xds_bootstrap.h +0 -1
- data/src/core/ext/xds/xds_bootstrap_grpc.cc +3 -12
- data/src/core/ext/xds/xds_bootstrap_grpc.h +16 -1
- data/src/core/ext/xds/xds_certificate_provider.cc +22 -25
- data/src/core/ext/xds/xds_channel_stack_modifier.cc +0 -1
- data/src/core/ext/xds/xds_client.cc +122 -90
- data/src/core/ext/xds/xds_client.h +7 -2
- data/src/core/ext/xds/xds_client_grpc.cc +5 -24
- data/src/core/ext/xds/xds_cluster.cc +291 -183
- data/src/core/ext/xds/xds_cluster.h +11 -15
- data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +32 -29
- data/src/core/ext/xds/xds_cluster_specifier_plugin.h +35 -16
- data/src/core/ext/xds/xds_common_types.cc +208 -141
- data/src/core/ext/xds/xds_common_types.h +19 -13
- data/src/core/ext/xds/xds_endpoint.cc +214 -129
- data/src/core/ext/xds/xds_endpoint.h +4 -7
- data/src/core/ext/xds/xds_http_fault_filter.cc +56 -43
- data/src/core/ext/xds/xds_http_fault_filter.h +13 -21
- data/src/core/ext/xds/xds_http_filters.cc +60 -73
- data/src/core/ext/xds/xds_http_filters.h +67 -19
- data/src/core/ext/xds/xds_http_rbac_filter.cc +152 -207
- data/src/core/ext/xds/xds_http_rbac_filter.h +12 -15
- data/src/core/ext/xds/xds_lb_policy_registry.cc +122 -169
- data/src/core/ext/xds/xds_lb_policy_registry.h +10 -11
- data/src/core/ext/xds/xds_listener.cc +459 -417
- data/src/core/ext/xds/xds_listener.h +43 -47
- data/src/core/ext/xds/xds_resource_type.h +3 -11
- data/src/core/ext/xds/xds_resource_type_impl.h +8 -13
- data/src/core/ext/xds/xds_route_config.cc +94 -80
- data/src/core/ext/xds/xds_route_config.h +10 -10
- data/src/core/ext/xds/xds_routing.cc +2 -1
- data/src/core/ext/xds/xds_routing.h +2 -0
- data/src/core/ext/xds/xds_server_config_fetcher.cc +109 -94
- data/src/core/ext/xds/xds_transport_grpc.cc +4 -5
- data/src/core/lib/address_utils/parse_address.cc +11 -10
- data/src/core/lib/channel/channel_args.h +16 -1
- data/src/core/lib/channel/channel_stack.cc +23 -20
- data/src/core/lib/channel/channel_stack.h +17 -4
- data/src/core/lib/channel/channel_stack_builder.cc +4 -7
- data/src/core/lib/channel/channel_stack_builder.h +14 -6
- data/src/core/lib/channel/channel_stack_builder_impl.cc +25 -7
- data/src/core/lib/channel/channel_stack_builder_impl.h +2 -0
- data/src/core/lib/channel/channel_trace.cc +4 -5
- data/src/core/lib/channel/channelz.cc +1 -1
- data/src/core/lib/channel/connected_channel.cc +695 -35
- data/src/core/lib/channel/connected_channel.h +0 -4
- data/src/core/lib/channel/promise_based_filter.cc +1004 -140
- data/src/core/lib/channel/promise_based_filter.h +364 -87
- data/src/core/lib/compression/message_compress.cc +5 -5
- data/src/core/lib/debug/event_log.cc +88 -0
- data/src/core/lib/debug/event_log.h +81 -0
- data/src/core/lib/debug/histogram_view.cc +69 -0
- data/src/core/lib/{slice/slice_refcount.cc → debug/histogram_view.h} +15 -13
- data/src/core/lib/debug/stats.cc +22 -119
- data/src/core/lib/debug/stats.h +29 -35
- data/src/core/lib/debug/stats_data.cc +224 -73
- data/src/core/lib/debug/stats_data.h +263 -122
- data/src/core/lib/event_engine/common_closures.h +71 -0
- data/src/core/lib/event_engine/default_event_engine.cc +38 -15
- data/src/core/lib/event_engine/default_event_engine.h +15 -3
- data/src/core/lib/event_engine/default_event_engine_factory.cc +2 -4
- data/src/core/lib/event_engine/memory_allocator.cc +1 -1
- data/src/core/lib/event_engine/poller.h +10 -4
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +618 -0
- data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +129 -0
- data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +901 -0
- data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +97 -0
- data/src/core/lib/event_engine/posix_engine/event_poller.h +111 -0
- data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +74 -0
- data/src/core/lib/event_engine/{executor/threaded_executor.cc → posix_engine/event_poller_posix_default.h} +13 -16
- data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +77 -0
- data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +179 -0
- data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +267 -0
- data/src/core/lib/event_engine/posix_engine/lockfree_event.h +73 -0
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +1270 -0
- data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +682 -0
- data/src/core/lib/event_engine/posix_engine/posix_engine.cc +453 -18
- data/src/core/lib/event_engine/posix_engine/posix_engine.h +148 -24
- data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +80 -0
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +1081 -0
- data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +361 -0
- data/src/core/lib/event_engine/posix_engine/timer.h +9 -8
- data/src/core/lib/event_engine/posix_engine/timer_manager.cc +57 -194
- data/src/core/lib/event_engine/posix_engine/timer_manager.h +21 -49
- data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +301 -0
- data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +179 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +126 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +45 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +151 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +45 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +76 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +67 -0
- data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +37 -0
- data/src/core/lib/event_engine/slice.cc +7 -6
- data/src/core/lib/event_engine/slice_buffer.cc +2 -2
- data/src/core/lib/event_engine/thread_pool.cc +106 -25
- data/src/core/lib/event_engine/thread_pool.h +32 -9
- data/src/core/lib/event_engine/windows/win_socket.cc +7 -7
- data/src/core/lib/event_engine/windows/windows_engine.cc +18 -12
- data/src/core/lib/event_engine/windows/windows_engine.h +8 -4
- data/src/core/lib/experiments/config.cc +1 -1
- data/src/core/lib/experiments/experiments.cc +13 -2
- data/src/core/lib/experiments/experiments.h +8 -1
- data/src/core/lib/gpr/cpu_linux.cc +6 -2
- data/src/core/lib/gpr/log_linux.cc +3 -4
- data/src/core/lib/gpr/string.h +1 -1
- data/src/core/lib/gpr/tmpfile_posix.cc +3 -2
- data/src/core/lib/gprpp/load_file.cc +75 -0
- data/src/core/lib/gprpp/load_file.h +33 -0
- data/src/core/lib/gprpp/per_cpu.h +46 -0
- data/src/core/lib/gprpp/stat_posix.cc +5 -4
- data/src/core/lib/gprpp/stat_windows.cc +3 -2
- data/src/core/lib/gprpp/status_helper.h +1 -3
- data/src/core/lib/gprpp/strerror.cc +41 -0
- data/src/core/{ext/xds/xds_resource_type.cc → lib/gprpp/strerror.h} +9 -13
- data/src/core/lib/gprpp/thd_windows.cc +1 -2
- data/src/core/lib/gprpp/time.cc +3 -4
- data/src/core/lib/gprpp/time.h +13 -2
- data/src/core/lib/gprpp/validation_errors.h +18 -1
- data/src/core/lib/http/httpcli.cc +40 -44
- data/src/core/lib/http/httpcli.h +6 -5
- data/src/core/lib/http/httpcli_security_connector.cc +4 -6
- data/src/core/lib/http/parser.cc +54 -65
- data/src/core/lib/iomgr/buffer_list.cc +105 -116
- data/src/core/lib/iomgr/buffer_list.h +60 -44
- data/src/core/lib/iomgr/call_combiner.cc +11 -10
- data/src/core/lib/iomgr/call_combiner.h +3 -4
- data/src/core/lib/iomgr/cfstream_handle.cc +13 -16
- data/src/core/lib/iomgr/closure.h +49 -5
- data/src/core/lib/iomgr/combiner.cc +2 -2
- data/src/core/lib/iomgr/endpoint.h +1 -1
- data/src/core/lib/iomgr/endpoint_cfstream.cc +26 -25
- data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -2
- data/src/core/lib/iomgr/error.cc +27 -42
- data/src/core/lib/iomgr/error.h +22 -152
- data/src/core/lib/iomgr/ev_apple.cc +4 -4
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +26 -25
- data/src/core/lib/iomgr/ev_poll_posix.cc +27 -31
- data/src/core/lib/iomgr/exec_ctx.cc +3 -4
- data/src/core/lib/iomgr/exec_ctx.h +2 -3
- data/src/core/lib/iomgr/executor.cc +1 -2
- data/src/core/lib/iomgr/internal_errqueue.cc +3 -1
- data/src/core/lib/iomgr/iocp_windows.cc +1 -0
- data/src/core/lib/iomgr/iomgr_posix.cc +2 -2
- data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +2 -1
- data/src/core/lib/iomgr/iomgr_windows.cc +2 -1
- data/src/core/lib/iomgr/load_file.cc +5 -9
- data/src/core/lib/iomgr/lockfree_event.cc +10 -10
- data/src/core/lib/iomgr/pollset_windows.cc +4 -4
- data/src/core/lib/iomgr/python_util.h +2 -2
- data/src/core/lib/iomgr/resolve_address.cc +8 -3
- data/src/core/lib/iomgr/resolve_address.h +3 -4
- data/src/core/lib/iomgr/resolve_address_impl.h +1 -1
- data/src/core/lib/iomgr/resolve_address_posix.cc +14 -25
- data/src/core/lib/iomgr/resolve_address_posix.h +1 -2
- data/src/core/lib/iomgr/resolve_address_windows.cc +14 -17
- data/src/core/lib/iomgr/resolve_address_windows.h +1 -2
- data/src/core/lib/iomgr/socket_utils_common_posix.cc +30 -29
- data/src/core/lib/iomgr/socket_utils_posix.cc +1 -0
- data/src/core/lib/iomgr/socket_utils_posix.h +2 -2
- data/src/core/lib/iomgr/socket_windows.cc +2 -2
- data/src/core/lib/iomgr/tcp_client_cfstream.cc +6 -10
- data/src/core/lib/iomgr/tcp_client_posix.cc +31 -35
- data/src/core/lib/iomgr/tcp_client_windows.cc +8 -12
- data/src/core/lib/iomgr/tcp_posix.cc +92 -108
- data/src/core/lib/iomgr/tcp_server_posix.cc +34 -34
- data/src/core/lib/iomgr/tcp_server_utils_posix.h +1 -1
- data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +18 -21
- data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +12 -13
- data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +1 -1
- data/src/core/lib/iomgr/tcp_server_windows.cc +26 -29
- data/src/core/lib/iomgr/tcp_windows.cc +27 -34
- data/src/core/lib/iomgr/timer.h +8 -8
- data/src/core/lib/iomgr/timer_generic.cc +9 -15
- data/src/core/lib/iomgr/unix_sockets_posix.cc +2 -4
- data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +4 -3
- data/src/core/lib/iomgr/wakeup_fd_pipe.cc +10 -8
- data/src/core/lib/json/json_channel_args.h +42 -0
- data/src/core/lib/json/json_object_loader.cc +7 -2
- data/src/core/lib/json/json_object_loader.h +22 -0
- data/src/core/lib/json/json_util.cc +5 -5
- data/src/core/lib/json/json_util.h +4 -4
- data/src/core/lib/load_balancing/lb_policy.cc +1 -1
- data/src/core/lib/load_balancing/lb_policy.h +4 -0
- data/src/core/lib/load_balancing/subchannel_interface.h +0 -7
- data/src/core/lib/matchers/matchers.cc +3 -4
- data/src/core/lib/promise/activity.cc +16 -2
- data/src/core/lib/promise/activity.h +38 -15
- data/src/core/lib/promise/arena_promise.h +80 -51
- data/src/core/lib/promise/context.h +13 -6
- data/src/core/lib/promise/detail/basic_seq.h +9 -28
- data/src/core/lib/promise/detail/promise_factory.h +58 -10
- data/src/core/lib/promise/detail/status.h +28 -0
- data/src/core/lib/promise/detail/switch.h +1455 -0
- data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +3 -1
- data/src/core/lib/promise/for_each.h +129 -0
- data/src/core/lib/promise/loop.h +7 -5
- data/src/core/lib/promise/map_pipe.h +87 -0
- data/src/core/lib/promise/pipe.cc +19 -0
- data/src/core/lib/promise/pipe.h +505 -0
- data/src/core/lib/promise/poll.h +13 -0
- data/src/core/lib/promise/seq.h +3 -5
- data/src/core/lib/promise/sleep.cc +5 -4
- data/src/core/lib/promise/sleep.h +1 -2
- data/src/core/lib/promise/try_concurrently.h +341 -0
- data/src/core/lib/promise/try_seq.h +10 -13
- data/src/core/lib/resolver/server_address.cc +1 -0
- data/src/core/lib/resolver/server_address.h +1 -3
- data/src/core/lib/resource_quota/api.cc +0 -1
- data/src/core/lib/resource_quota/arena.cc +19 -0
- data/src/core/lib/resource_quota/arena.h +89 -0
- data/src/core/lib/resource_quota/memory_quota.cc +1 -0
- data/src/core/lib/security/authorization/grpc_authorization_engine.cc +1 -3
- data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +4 -2
- data/src/core/lib/security/authorization/matchers.cc +25 -22
- data/src/core/lib/security/authorization/rbac_policy.cc +2 -3
- data/src/core/lib/security/context/security_context.h +10 -0
- data/src/core/lib/security/credentials/channel_creds_registry_init.cc +3 -4
- data/src/core/lib/security/credentials/composite/composite_credentials.cc +1 -1
- data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +77 -55
- data/src/core/lib/security/credentials/external/aws_request_signer.cc +4 -3
- data/src/core/lib/security/credentials/external/external_account_credentials.cc +40 -51
- data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +17 -21
- data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +21 -25
- data/src/core/lib/security/credentials/fake/fake_credentials.cc +1 -0
- data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -24
- data/src/core/lib/security/credentials/iam/iam_credentials.cc +1 -0
- data/src/core/lib/security/credentials/jwt/json_token.cc +1 -2
- data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +1 -1
- data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +5 -5
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +24 -30
- data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +6 -5
- data/src/core/lib/security/credentials/plugin/plugin_credentials.h +3 -3
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +19 -27
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +4 -11
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +29 -41
- data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +1 -1
- data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +6 -11
- data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +8 -15
- 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 +2 -6
- data/src/core/lib/security/security_connector/load_system_roots_supported.cc +1 -4
- data/src/core/lib/security/security_connector/local/local_security_connector.cc +7 -11
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +9 -14
- data/src/core/lib/security/security_connector/ssl_utils.cc +5 -7
- data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -27
- data/src/core/lib/security/transport/client_auth_filter.cc +1 -1
- data/src/core/lib/security/transport/secure_endpoint.cc +26 -28
- data/src/core/lib/security/transport/security_handshaker.cc +53 -53
- data/src/core/lib/security/transport/server_auth_filter.cc +21 -21
- data/src/core/lib/security/transport/tsi_error.cc +6 -3
- data/src/core/lib/security/util/json_util.cc +4 -5
- data/src/core/lib/service_config/service_config.h +1 -1
- data/src/core/lib/service_config/service_config_impl.cc +111 -158
- data/src/core/lib/service_config/service_config_impl.h +14 -17
- data/src/core/lib/service_config/service_config_parser.cc +14 -31
- data/src/core/lib/service_config/service_config_parser.h +14 -10
- data/src/core/lib/slice/b64.cc +2 -2
- data/src/core/lib/slice/slice.cc +7 -1
- data/src/core/lib/slice/slice.h +19 -6
- data/src/core/lib/slice/slice_buffer.cc +13 -14
- data/src/core/lib/slice/slice_internal.h +13 -21
- data/src/core/lib/slice/slice_refcount.h +34 -19
- data/src/core/lib/surface/byte_buffer.cc +3 -4
- data/src/core/lib/surface/byte_buffer_reader.cc +4 -4
- data/src/core/lib/surface/call.cc +1366 -239
- data/src/core/lib/surface/call.h +44 -0
- data/src/core/lib/surface/call_details.cc +3 -3
- data/src/core/lib/surface/call_trace.cc +113 -0
- data/src/core/lib/surface/call_trace.h +30 -0
- data/src/core/lib/surface/channel.cc +44 -49
- data/src/core/lib/surface/channel.h +9 -1
- data/src/core/lib/surface/channel_ping.cc +1 -1
- data/src/core/lib/surface/channel_stack_type.cc +4 -0
- data/src/core/lib/surface/channel_stack_type.h +2 -0
- data/src/core/lib/surface/completion_queue.cc +38 -52
- data/src/core/lib/surface/init.cc +8 -39
- data/src/core/lib/surface/init_internally.h +8 -0
- data/src/core/lib/surface/lame_client.cc +10 -8
- data/src/core/lib/surface/server.cc +48 -70
- data/src/core/lib/surface/server.h +3 -4
- data/src/core/lib/surface/validate_metadata.cc +11 -12
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/connectivity_state.cc +2 -2
- data/src/core/lib/transport/error_utils.cc +34 -28
- data/src/core/lib/transport/error_utils.h +3 -3
- data/src/core/lib/transport/handshaker.cc +14 -14
- data/src/core/lib/transport/handshaker.h +1 -1
- data/src/core/lib/transport/handshaker_factory.h +26 -0
- data/src/core/lib/transport/handshaker_registry.cc +8 -2
- data/src/core/lib/transport/handshaker_registry.h +3 -4
- data/src/core/lib/transport/http_connect_handshaker.cc +23 -24
- data/src/core/lib/transport/metadata_batch.h +17 -1
- data/src/core/lib/transport/parsed_metadata.cc +2 -6
- data/src/core/lib/transport/tcp_connect_handshaker.cc +15 -20
- data/src/core/lib/transport/transport.cc +63 -17
- data/src/core/lib/transport/transport.h +64 -68
- data/src/core/lib/transport/transport_impl.h +1 -1
- data/src/core/lib/transport/transport_op_string.cc +7 -6
- data/src/core/plugin_registry/grpc_plugin_registry.cc +6 -10
- data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +2 -14
- data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +10 -10
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +8 -8
- data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -1
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +7 -7
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +7 -6
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +1 -1
- data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +5 -5
- data/src/core/tsi/fake_transport_security.cc +3 -3
- data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +7 -3
- data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +1 -1
- data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +6 -2
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +0 -2
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +0 -3
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/spec/channel_spec.rb +0 -43
- data/src/ruby/spec/generic/active_call_spec.rb +12 -3
- data/third_party/abseil-cpp/absl/cleanup/cleanup.h +140 -0
- data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +100 -0
- data/third_party/zlib/compress.c +3 -3
- data/third_party/zlib/crc32.c +21 -12
- data/third_party/zlib/deflate.c +112 -106
- data/third_party/zlib/deflate.h +2 -2
- data/third_party/zlib/gzlib.c +1 -1
- data/third_party/zlib/gzread.c +3 -5
- data/third_party/zlib/gzwrite.c +1 -1
- data/third_party/zlib/infback.c +10 -7
- data/third_party/zlib/inflate.c +5 -2
- data/third_party/zlib/inftrees.c +2 -2
- data/third_party/zlib/inftrees.h +1 -1
- data/third_party/zlib/trees.c +61 -62
- data/third_party/zlib/uncompr.c +2 -2
- data/third_party/zlib/zconf.h +16 -3
- data/third_party/zlib/zlib.h +10 -10
- data/third_party/zlib/zutil.c +9 -7
- data/third_party/zlib/zutil.h +1 -0
- metadata +57 -20
- data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +0 -188
- data/src/core/ext/filters/fault_injection/service_config_parser.cc +0 -187
- data/src/core/lib/event_engine/executor/threaded_executor.h +0 -44
- data/src/core/lib/gpr/murmur_hash.cc +0 -82
- data/src/core/lib/gpr/murmur_hash.h +0 -29
- data/src/core/lib/gpr/tls.h +0 -156
- data/src/core/lib/promise/call_push_pull.h +0 -148
- data/src/core/lib/slice/slice_api.cc +0 -39
- data/src/core/lib/slice/slice_buffer_api.cc +0 -35
- data/src/core/lib/slice/slice_refcount_base.h +0 -60
@@ -20,19 +20,57 @@
|
|
20
20
|
|
21
21
|
#include "src/core/lib/channel/connected_channel.h"
|
22
22
|
|
23
|
+
#include <inttypes.h>
|
24
|
+
#include <string.h>
|
25
|
+
|
26
|
+
#include <algorithm>
|
27
|
+
#include <memory>
|
28
|
+
#include <string>
|
29
|
+
#include <utility>
|
30
|
+
#include <vector>
|
31
|
+
|
32
|
+
#include "absl/base/thread_annotations.h"
|
33
|
+
#include "absl/status/status.h"
|
34
|
+
#include "absl/strings/str_cat.h"
|
35
|
+
#include "absl/strings/str_join.h"
|
36
|
+
#include "absl/types/optional.h"
|
37
|
+
#include "absl/types/variant.h"
|
38
|
+
|
23
39
|
#include <grpc/impl/codegen/grpc_types.h>
|
24
40
|
#include <grpc/support/alloc.h>
|
25
41
|
#include <grpc/support/log.h>
|
26
42
|
|
27
43
|
#include "src/core/lib/channel/channel_args.h"
|
44
|
+
#include "src/core/lib/channel/channel_fwd.h"
|
28
45
|
#include "src/core/lib/channel/channel_stack.h"
|
46
|
+
#include "src/core/lib/channel/context.h"
|
47
|
+
#include "src/core/lib/debug/trace.h"
|
29
48
|
#include "src/core/lib/gpr/alloc.h"
|
49
|
+
#include "src/core/lib/gprpp/debug_location.h"
|
50
|
+
#include "src/core/lib/gprpp/match.h"
|
51
|
+
#include "src/core/lib/gprpp/orphanable.h"
|
52
|
+
#include "src/core/lib/gprpp/status_helper.h"
|
53
|
+
#include "src/core/lib/gprpp/sync.h"
|
30
54
|
#include "src/core/lib/iomgr/call_combiner.h"
|
31
55
|
#include "src/core/lib/iomgr/closure.h"
|
32
56
|
#include "src/core/lib/iomgr/error.h"
|
57
|
+
#include "src/core/lib/iomgr/exec_ctx.h"
|
33
58
|
#include "src/core/lib/iomgr/polling_entity.h"
|
59
|
+
#include "src/core/lib/promise/activity.h"
|
60
|
+
#include "src/core/lib/promise/arena_promise.h"
|
61
|
+
#include "src/core/lib/promise/context.h"
|
62
|
+
#include "src/core/lib/promise/latch.h"
|
63
|
+
#include "src/core/lib/promise/pipe.h"
|
64
|
+
#include "src/core/lib/promise/poll.h"
|
65
|
+
#include "src/core/lib/resource_quota/arena.h"
|
66
|
+
#include "src/core/lib/slice/slice_buffer.h"
|
67
|
+
#include "src/core/lib/surface/call.h"
|
68
|
+
#include "src/core/lib/surface/call_trace.h"
|
69
|
+
#include "src/core/lib/surface/channel_stack_type.h"
|
70
|
+
#include "src/core/lib/transport/metadata_batch.h"
|
34
71
|
#include "src/core/lib/transport/transport.h"
|
35
72
|
#include "src/core/lib/transport/transport_fwd.h"
|
73
|
+
#include "src/core/lib/transport/transport_impl.h"
|
36
74
|
|
37
75
|
#define MAX_BUFFER_LENGTH 8192
|
38
76
|
|
@@ -57,8 +95,8 @@ typedef struct connected_channel_call_data {
|
|
57
95
|
|
58
96
|
static void run_in_call_combiner(void* arg, grpc_error_handle error) {
|
59
97
|
callback_state* state = static_cast<callback_state*>(arg);
|
60
|
-
GRPC_CALL_COMBINER_START(state->call_combiner, state->original_closure,
|
61
|
-
|
98
|
+
GRPC_CALL_COMBINER_START(state->call_combiner, state->original_closure, error,
|
99
|
+
state->reason);
|
62
100
|
}
|
63
101
|
|
64
102
|
static void run_cancel_in_call_combiner(void* arg, grpc_error_handle error) {
|
@@ -156,9 +194,8 @@ static grpc_error_handle connected_channel_init_call_elem(
|
|
156
194
|
int r = grpc_transport_init_stream(
|
157
195
|
chand->transport, TRANSPORT_STREAM_FROM_CALL_DATA(calld),
|
158
196
|
&args->call_stack->refcount, args->server_transport_data, args->arena);
|
159
|
-
return r == 0 ?
|
160
|
-
:
|
161
|
-
"transport stream initialization failed");
|
197
|
+
return r == 0 ? absl::OkStatus()
|
198
|
+
: GRPC_ERROR_CREATE("transport stream initialization failed");
|
162
199
|
}
|
163
200
|
|
164
201
|
static void set_pollset_or_pollset_set(grpc_call_element* elem,
|
@@ -187,7 +224,7 @@ static grpc_error_handle connected_channel_init_channel_elem(
|
|
187
224
|
GPR_ASSERT(args->is_last);
|
188
225
|
cd->transport = grpc_channel_args_find_pointer<grpc_transport>(
|
189
226
|
args->channel_args, GRPC_ARG_TRANSPORT);
|
190
|
-
return
|
227
|
+
return absl::OkStatus();
|
191
228
|
}
|
192
229
|
|
193
230
|
/* Destructor for channel_data */
|
@@ -203,39 +240,662 @@ static void connected_channel_get_channel_info(
|
|
203
240
|
grpc_channel_element* /*elem*/, const grpc_channel_info* /*channel_info*/) {
|
204
241
|
}
|
205
242
|
|
206
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
243
|
+
namespace grpc_core {
|
244
|
+
namespace {
|
245
|
+
|
246
|
+
class ClientStream : public Orphanable {
|
247
|
+
public:
|
248
|
+
ClientStream(grpc_transport* transport, CallArgs call_args)
|
249
|
+
: transport_(transport),
|
250
|
+
stream_(nullptr, StreamDeleter(this)),
|
251
|
+
server_initial_metadata_latch_(call_args.server_initial_metadata),
|
252
|
+
client_to_server_messages_(call_args.outgoing_messages),
|
253
|
+
server_to_client_messages_(call_args.incoming_messages),
|
254
|
+
client_initial_metadata_(std::move(call_args.client_initial_metadata)) {
|
255
|
+
call_context_->IncrementRefCount("client_stream");
|
256
|
+
GRPC_STREAM_REF_INIT(
|
257
|
+
&stream_refcount_, 1,
|
258
|
+
[](void* p, grpc_error_handle) {
|
259
|
+
static_cast<ClientStream*>(p)->BeginDestroy();
|
260
|
+
},
|
261
|
+
this, "client_stream");
|
262
|
+
if (grpc_call_trace.enabled()) {
|
263
|
+
gpr_log(GPR_INFO, "%sInitImpl: intitial_metadata=%s",
|
264
|
+
Activity::current()->DebugTag().c_str(),
|
265
|
+
client_initial_metadata_->DebugString().c_str());
|
266
|
+
}
|
267
|
+
}
|
268
|
+
|
269
|
+
void Orphan() override {
|
270
|
+
bool finished;
|
271
|
+
{
|
272
|
+
MutexLock lock(&mu_);
|
273
|
+
if (grpc_call_trace.enabled()) {
|
274
|
+
gpr_log(GPR_INFO, "%sDropStream: %s",
|
275
|
+
Activity::current()->DebugTag().c_str(),
|
276
|
+
ActiveOpsString().c_str());
|
277
|
+
}
|
278
|
+
finished = finished_;
|
279
|
+
}
|
280
|
+
// If we hadn't already observed the stream to be finished, we need to
|
281
|
+
// cancel it at the transport.
|
282
|
+
if (!finished) {
|
283
|
+
IncrementRefCount("shutdown client stream");
|
284
|
+
auto* cancel_op =
|
285
|
+
GetContext<Arena>()->New<grpc_transport_stream_op_batch>();
|
286
|
+
cancel_op->cancel_stream = true;
|
287
|
+
cancel_op->payload = &batch_payload_;
|
288
|
+
auto* stream = stream_.get();
|
289
|
+
cancel_op->on_complete = NewClosure(
|
290
|
+
[this](grpc_error_handle) { Unref("shutdown client stream"); });
|
291
|
+
batch_payload_.cancel_stream.cancel_error = absl::CancelledError();
|
292
|
+
grpc_transport_perform_stream_op(transport_, stream, cancel_op);
|
293
|
+
}
|
294
|
+
Unref("orphan client stream");
|
295
|
+
}
|
296
|
+
|
297
|
+
void IncrementRefCount(const char* reason) {
|
298
|
+
#ifndef NDEBUG
|
299
|
+
grpc_stream_ref(&stream_refcount_, reason);
|
300
|
+
#else
|
301
|
+
(void)reason;
|
302
|
+
grpc_stream_ref(&stream_refcount_);
|
303
|
+
#endif
|
304
|
+
}
|
305
|
+
|
306
|
+
void Unref(const char* reason) {
|
307
|
+
#ifndef NDEBUG
|
308
|
+
grpc_stream_unref(&stream_refcount_, reason);
|
309
|
+
#else
|
310
|
+
(void)reason;
|
311
|
+
grpc_stream_unref(&stream_refcount_);
|
312
|
+
#endif
|
313
|
+
}
|
314
|
+
|
315
|
+
void BeginDestroy() {
|
316
|
+
if (stream_ != nullptr) {
|
317
|
+
stream_.reset();
|
318
|
+
} else {
|
319
|
+
StreamDestroyed();
|
320
|
+
}
|
321
|
+
}
|
322
|
+
|
323
|
+
Poll<ServerMetadataHandle> PollOnce() {
|
324
|
+
MutexLock lock(&mu_);
|
325
|
+
GPR_ASSERT(!finished_);
|
326
|
+
|
327
|
+
if (grpc_call_trace.enabled()) {
|
328
|
+
gpr_log(GPR_INFO, "%sPollConnectedChannel: %s",
|
329
|
+
Activity::current()->DebugTag().c_str(),
|
330
|
+
ActiveOpsString().c_str());
|
331
|
+
}
|
332
|
+
|
333
|
+
auto push_recv_message = [this]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_) {
|
334
|
+
recv_message_state_ = PendingReceiveMessage{};
|
335
|
+
auto& pending_recv_message =
|
336
|
+
absl::get<PendingReceiveMessage>(recv_message_state_);
|
337
|
+
memset(&recv_message_, 0, sizeof(recv_message_));
|
338
|
+
recv_message_.payload = &batch_payload_;
|
339
|
+
recv_message_.on_complete = nullptr;
|
340
|
+
recv_message_.recv_message = true;
|
341
|
+
batch_payload_.recv_message.recv_message = &pending_recv_message.payload;
|
342
|
+
batch_payload_.recv_message.flags = &pending_recv_message.flags;
|
343
|
+
batch_payload_.recv_message.call_failed_before_recv_message = nullptr;
|
344
|
+
batch_payload_.recv_message.recv_message_ready =
|
345
|
+
&recv_message_batch_done_;
|
346
|
+
IncrementRefCount("recv_message");
|
347
|
+
recv_message_waker_ = Activity::current()->MakeOwningWaker();
|
348
|
+
push_recv_message_ = true;
|
349
|
+
SchedulePush();
|
350
|
+
};
|
351
|
+
|
352
|
+
if (!std::exchange(requested_metadata_, true)) {
|
353
|
+
if (grpc_call_trace.enabled()) {
|
354
|
+
gpr_log(GPR_INFO, "%sPollConnectedChannel: requesting metadata",
|
355
|
+
Activity::current()->DebugTag().c_str());
|
356
|
+
}
|
357
|
+
stream_.reset(static_cast<grpc_stream*>(
|
358
|
+
GetContext<Arena>()->Alloc(transport_->vtable->sizeof_stream)));
|
359
|
+
grpc_transport_init_stream(transport_, stream_.get(), &stream_refcount_,
|
360
|
+
nullptr, GetContext<Arena>());
|
361
|
+
grpc_transport_set_pops(transport_, stream_.get(),
|
362
|
+
GetContext<CallContext>()->polling_entity());
|
363
|
+
memset(&metadata_, 0, sizeof(metadata_));
|
364
|
+
metadata_.send_initial_metadata = true;
|
365
|
+
metadata_.recv_initial_metadata = true;
|
366
|
+
metadata_.recv_trailing_metadata = true;
|
367
|
+
metadata_.payload = &batch_payload_;
|
368
|
+
metadata_.on_complete = &metadata_batch_done_;
|
369
|
+
batch_payload_.send_initial_metadata.send_initial_metadata =
|
370
|
+
client_initial_metadata_.get();
|
371
|
+
batch_payload_.send_initial_metadata.peer_string =
|
372
|
+
GetContext<CallContext>()->peer_string_atm_ptr();
|
373
|
+
server_initial_metadata_ =
|
374
|
+
GetContext<Arena>()->MakePooled<ServerMetadata>(GetContext<Arena>());
|
375
|
+
batch_payload_.recv_initial_metadata.recv_initial_metadata =
|
376
|
+
server_initial_metadata_.get();
|
377
|
+
batch_payload_.recv_initial_metadata.recv_initial_metadata_ready =
|
378
|
+
&recv_initial_metadata_ready_;
|
379
|
+
batch_payload_.recv_initial_metadata.trailing_metadata_available =
|
380
|
+
nullptr;
|
381
|
+
batch_payload_.recv_initial_metadata.peer_string = nullptr;
|
382
|
+
server_trailing_metadata_ =
|
383
|
+
GetContext<Arena>()->MakePooled<ServerMetadata>(GetContext<Arena>());
|
384
|
+
batch_payload_.recv_trailing_metadata.recv_trailing_metadata =
|
385
|
+
server_trailing_metadata_.get();
|
386
|
+
batch_payload_.recv_trailing_metadata.collect_stats =
|
387
|
+
&GetContext<CallContext>()->call_stats()->transport_stream_stats;
|
388
|
+
batch_payload_.recv_trailing_metadata.recv_trailing_metadata_ready =
|
389
|
+
&recv_trailing_metadata_ready_;
|
390
|
+
push_metadata_ = true;
|
391
|
+
IncrementRefCount("metadata_batch_done");
|
392
|
+
IncrementRefCount("initial_metadata_ready");
|
393
|
+
IncrementRefCount("trailing_metadata_ready");
|
394
|
+
initial_metadata_waker_ = Activity::current()->MakeOwningWaker();
|
395
|
+
trailing_metadata_waker_ = Activity::current()->MakeOwningWaker();
|
396
|
+
SchedulePush();
|
397
|
+
}
|
398
|
+
if (absl::holds_alternative<Closed>(send_message_state_)) {
|
399
|
+
message_to_send_.reset();
|
400
|
+
}
|
401
|
+
if (absl::holds_alternative<Idle>(send_message_state_)) {
|
402
|
+
message_to_send_.reset();
|
403
|
+
send_message_state_ = client_to_server_messages_->Next();
|
404
|
+
}
|
405
|
+
if (auto* next = absl::get_if<PipeReceiver<MessageHandle>::NextType>(
|
406
|
+
&send_message_state_)) {
|
407
|
+
auto r = (*next)();
|
408
|
+
if (auto* p = absl::get_if<NextResult<MessageHandle>>(&r)) {
|
409
|
+
memset(&send_message_, 0, sizeof(send_message_));
|
410
|
+
send_message_.payload = &batch_payload_;
|
411
|
+
send_message_.on_complete = &send_message_batch_done_;
|
412
|
+
// No value => half close from above.
|
413
|
+
if (p->has_value()) {
|
414
|
+
message_to_send_ = std::move(**p);
|
415
|
+
send_message_state_ = SendMessageToTransport{};
|
416
|
+
send_message_.send_message = true;
|
417
|
+
batch_payload_.send_message.send_message =
|
418
|
+
message_to_send_->payload();
|
419
|
+
batch_payload_.send_message.flags = message_to_send_->flags();
|
420
|
+
} else {
|
421
|
+
GPR_ASSERT(!absl::holds_alternative<Closed>(send_message_state_));
|
422
|
+
client_trailing_metadata_ =
|
423
|
+
GetContext<Arena>()->MakePooled<ClientMetadata>(
|
424
|
+
GetContext<Arena>());
|
425
|
+
send_message_state_ = Closed{};
|
426
|
+
send_message_.send_trailing_metadata = true;
|
427
|
+
batch_payload_.send_trailing_metadata.send_trailing_metadata =
|
428
|
+
client_trailing_metadata_.get();
|
429
|
+
batch_payload_.send_trailing_metadata.sent = nullptr;
|
430
|
+
}
|
431
|
+
IncrementRefCount("send_message");
|
432
|
+
send_message_waker_ = Activity::current()->MakeOwningWaker();
|
433
|
+
push_send_message_ = true;
|
434
|
+
SchedulePush();
|
435
|
+
}
|
436
|
+
}
|
437
|
+
if (auto* pending =
|
438
|
+
absl::get_if<PendingReceiveMessage>(&recv_message_state_)) {
|
439
|
+
if (pending->received) {
|
440
|
+
if (pending->payload.has_value()) {
|
441
|
+
if (grpc_call_trace.enabled()) {
|
442
|
+
gpr_log(GPR_INFO,
|
443
|
+
"%sRecvMessageBatchDone: received payload of %" PRIdPTR
|
444
|
+
" bytes",
|
445
|
+
recv_message_waker_.ActivityDebugTag().c_str(),
|
446
|
+
pending->payload->Length());
|
447
|
+
}
|
448
|
+
recv_message_state_ = server_to_client_messages_->Push(
|
449
|
+
GetContext<Arena>()->MakePooled<Message>(
|
450
|
+
std::move(*pending->payload), pending->flags));
|
451
|
+
} else {
|
452
|
+
if (grpc_call_trace.enabled()) {
|
453
|
+
gpr_log(GPR_INFO, "%sRecvMessageBatchDone: received no payload",
|
454
|
+
recv_message_waker_.ActivityDebugTag().c_str());
|
455
|
+
}
|
456
|
+
recv_message_state_ = Closed{};
|
457
|
+
std::exchange(server_to_client_messages_, nullptr)->Close();
|
458
|
+
}
|
459
|
+
}
|
460
|
+
}
|
461
|
+
if (server_initial_metadata_state_ ==
|
462
|
+
ServerInitialMetadataState::kReceivedButNotSet) {
|
463
|
+
server_initial_metadata_state_ = ServerInitialMetadataState::kSet;
|
464
|
+
server_initial_metadata_latch_->Set(server_initial_metadata_.get());
|
465
|
+
}
|
466
|
+
if (absl::holds_alternative<Idle>(recv_message_state_)) {
|
467
|
+
if (grpc_call_trace.enabled()) {
|
468
|
+
gpr_log(GPR_INFO, "%sPollConnectedChannel: requesting message",
|
469
|
+
Activity::current()->DebugTag().c_str());
|
470
|
+
}
|
471
|
+
push_recv_message();
|
472
|
+
}
|
473
|
+
if (server_initial_metadata_state_ == ServerInitialMetadataState::kSet &&
|
474
|
+
!absl::holds_alternative<PipeSender<MessageHandle>::PushType>(
|
475
|
+
recv_message_state_) &&
|
476
|
+
std::exchange(queued_trailing_metadata_, false)) {
|
477
|
+
if (grpc_call_trace.enabled()) {
|
478
|
+
gpr_log(GPR_INFO,
|
479
|
+
"%sPollConnectedChannel: finished request, returning: {%s}; "
|
480
|
+
"active_ops: %s",
|
481
|
+
Activity::current()->DebugTag().c_str(),
|
482
|
+
server_trailing_metadata_->DebugString().c_str(),
|
483
|
+
ActiveOpsString().c_str());
|
484
|
+
}
|
485
|
+
finished_ = true;
|
486
|
+
return ServerMetadataHandle(std::move(server_trailing_metadata_));
|
487
|
+
}
|
488
|
+
if (auto* push = absl::get_if<PipeSender<MessageHandle>::PushType>(
|
489
|
+
&recv_message_state_)) {
|
490
|
+
auto r = (*push)();
|
491
|
+
if (bool* result = absl::get_if<bool>(&r)) {
|
492
|
+
if (*result) {
|
493
|
+
if (!finished_) {
|
494
|
+
if (grpc_call_trace.enabled()) {
|
495
|
+
gpr_log(GPR_INFO,
|
496
|
+
"%sPollConnectedChannel: pushed message; requesting next",
|
497
|
+
Activity::current()->DebugTag().c_str());
|
498
|
+
}
|
499
|
+
push_recv_message();
|
500
|
+
} else {
|
501
|
+
if (grpc_call_trace.enabled()) {
|
502
|
+
gpr_log(GPR_INFO,
|
503
|
+
"%sPollConnectedChannel: pushed message and finished; "
|
504
|
+
"marking closed",
|
505
|
+
Activity::current()->DebugTag().c_str());
|
506
|
+
}
|
507
|
+
recv_message_state_ = Closed{};
|
508
|
+
}
|
509
|
+
} else {
|
510
|
+
if (grpc_call_trace.enabled()) {
|
511
|
+
gpr_log(GPR_INFO,
|
512
|
+
"%sPollConnectedChannel: failed to push message; marking "
|
513
|
+
"closed",
|
514
|
+
Activity::current()->DebugTag().c_str());
|
515
|
+
}
|
516
|
+
recv_message_state_ = Closed{};
|
517
|
+
}
|
518
|
+
}
|
519
|
+
}
|
520
|
+
return Pending{};
|
521
|
+
}
|
522
|
+
|
523
|
+
void RecvInitialMetadataReady(grpc_error_handle error) {
|
524
|
+
GPR_ASSERT(error == absl::OkStatus());
|
525
|
+
{
|
526
|
+
MutexLock lock(&mu_);
|
527
|
+
server_initial_metadata_state_ =
|
528
|
+
ServerInitialMetadataState::kReceivedButNotSet;
|
529
|
+
initial_metadata_waker_.Wakeup();
|
530
|
+
}
|
531
|
+
Unref("initial_metadata_ready");
|
532
|
+
}
|
533
|
+
|
534
|
+
void RecvTrailingMetadataReady(grpc_error_handle error) {
|
535
|
+
GPR_ASSERT(error == absl::OkStatus());
|
536
|
+
{
|
537
|
+
MutexLock lock(&mu_);
|
538
|
+
queued_trailing_metadata_ = true;
|
539
|
+
trailing_metadata_waker_.Wakeup();
|
540
|
+
}
|
541
|
+
Unref("trailing_metadata_ready");
|
542
|
+
}
|
543
|
+
|
544
|
+
void MetadataBatchDone(grpc_error_handle error) {
|
545
|
+
GPR_ASSERT(error == absl::OkStatus());
|
546
|
+
Unref("metadata_batch_done");
|
547
|
+
}
|
548
|
+
|
549
|
+
void SendMessageBatchDone(grpc_error_handle error) {
|
550
|
+
{
|
551
|
+
MutexLock lock(&mu_);
|
552
|
+
if (error != absl::OkStatus()) {
|
553
|
+
// Note that we're in error here, the call will be closed by the
|
554
|
+
// transport in a moment, and we'll return from the promise with an
|
555
|
+
// error - so we don't need to do any extra work to close out pipes or
|
556
|
+
// the like.
|
557
|
+
send_message_state_ = Closed{};
|
558
|
+
}
|
559
|
+
if (!absl::holds_alternative<Closed>(send_message_state_)) {
|
560
|
+
send_message_state_ = Idle{};
|
561
|
+
}
|
562
|
+
send_message_waker_.Wakeup();
|
563
|
+
}
|
564
|
+
Unref("send_message");
|
565
|
+
}
|
566
|
+
|
567
|
+
void RecvMessageBatchDone(grpc_error_handle error) {
|
568
|
+
{
|
569
|
+
MutexLock lock(&mu_);
|
570
|
+
if (error != absl::OkStatus()) {
|
571
|
+
if (grpc_call_trace.enabled()) {
|
572
|
+
gpr_log(GPR_INFO, "%sRecvMessageBatchDone: error=%s",
|
573
|
+
recv_message_waker_.ActivityDebugTag().c_str(),
|
574
|
+
StatusToString(error).c_str());
|
575
|
+
}
|
576
|
+
} else if (absl::holds_alternative<Closed>(recv_message_state_)) {
|
577
|
+
if (grpc_call_trace.enabled()) {
|
578
|
+
gpr_log(GPR_INFO, "%sRecvMessageBatchDone: already closed, ignoring",
|
579
|
+
recv_message_waker_.ActivityDebugTag().c_str());
|
580
|
+
}
|
581
|
+
} else {
|
582
|
+
auto pending =
|
583
|
+
absl::get_if<PendingReceiveMessage>(&recv_message_state_);
|
584
|
+
GPR_ASSERT(pending != nullptr);
|
585
|
+
GPR_ASSERT(pending->received == false);
|
586
|
+
pending->received = true;
|
587
|
+
}
|
588
|
+
recv_message_waker_.Wakeup();
|
589
|
+
}
|
590
|
+
Unref("recv_message");
|
591
|
+
}
|
592
|
+
|
593
|
+
// Called from outside the activity to push work down to the transport.
|
594
|
+
void Push() {
|
595
|
+
auto do_push = [this](grpc_transport_stream_op_batch* batch) {
|
596
|
+
if (stream_ != nullptr) {
|
597
|
+
grpc_transport_perform_stream_op(transport_, stream_.get(), batch);
|
598
|
+
} else {
|
599
|
+
grpc_transport_stream_op_batch_finish_with_failure_from_transport(
|
600
|
+
batch, absl::CancelledError());
|
601
|
+
}
|
602
|
+
};
|
603
|
+
bool push_metadata;
|
604
|
+
bool push_send_message;
|
605
|
+
bool push_recv_message;
|
606
|
+
{
|
607
|
+
MutexLock lock(&mu_);
|
608
|
+
push_metadata = std::exchange(push_metadata_, false);
|
609
|
+
push_send_message = std::exchange(push_send_message_, false);
|
610
|
+
push_recv_message = std::exchange(push_recv_message_, false);
|
611
|
+
scheduled_push_ = false;
|
612
|
+
}
|
613
|
+
if (push_metadata) do_push(&metadata_);
|
614
|
+
if (push_send_message) do_push(&send_message_);
|
615
|
+
if (push_recv_message) do_push(&recv_message_);
|
616
|
+
Unref("push");
|
617
|
+
}
|
618
|
+
|
619
|
+
void StreamDestroyed() {
|
620
|
+
call_context_->RunInContext([this] {
|
621
|
+
auto* cc = call_context_;
|
622
|
+
this->~ClientStream();
|
623
|
+
cc->Unref("child_stream");
|
624
|
+
});
|
625
|
+
}
|
626
|
+
|
627
|
+
private:
|
628
|
+
struct Idle {};
|
629
|
+
struct Closed {};
|
630
|
+
struct SendMessageToTransport {};
|
631
|
+
|
632
|
+
enum class ServerInitialMetadataState : uint8_t {
|
633
|
+
// Initial metadata has not been received from the server.
|
634
|
+
kNotReceived,
|
635
|
+
// Initial metadata has been received from the server via the transport, but
|
636
|
+
// has not yet been set on the latch to publish it up the call stack.
|
637
|
+
kReceivedButNotSet,
|
638
|
+
// Initial metadata has been received from the server via the transport and
|
639
|
+
// has been set on the latch to publish it up the call stack.
|
640
|
+
kSet,
|
641
|
+
};
|
642
|
+
|
643
|
+
class StreamDeleter {
|
644
|
+
public:
|
645
|
+
explicit StreamDeleter(ClientStream* impl) : impl_(impl) {}
|
646
|
+
void operator()(grpc_stream* stream) const {
|
647
|
+
if (stream == nullptr) return;
|
648
|
+
grpc_transport_destroy_stream(impl_->transport_, stream,
|
649
|
+
&impl_->stream_destroyed_);
|
650
|
+
}
|
651
|
+
|
652
|
+
private:
|
653
|
+
ClientStream* impl_;
|
654
|
+
};
|
655
|
+
using StreamPtr = std::unique_ptr<grpc_stream, StreamDeleter>;
|
656
|
+
|
657
|
+
void SchedulePush() ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_) {
|
658
|
+
if (std::exchange(scheduled_push_, true)) return;
|
659
|
+
IncrementRefCount("push");
|
660
|
+
ExecCtx::Run(DEBUG_LOCATION, &push_, absl::OkStatus());
|
661
|
+
}
|
662
|
+
|
663
|
+
std::string ActiveOpsString() const ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_) {
|
664
|
+
std::vector<std::string> ops;
|
665
|
+
if (finished_) ops.push_back("FINISHED");
|
666
|
+
// Pushes
|
667
|
+
std::vector<std::string> pushes;
|
668
|
+
if (push_metadata_) pushes.push_back("metadata");
|
669
|
+
if (push_send_message_) pushes.push_back("send_message");
|
670
|
+
if (push_recv_message_) pushes.push_back("recv_message");
|
671
|
+
if (!pushes.empty()) {
|
672
|
+
ops.push_back(
|
673
|
+
absl::StrCat(scheduled_push_ ? "push:" : "unscheduled-push:",
|
674
|
+
absl::StrJoin(pushes, ",")));
|
675
|
+
} else if (scheduled_push_) {
|
676
|
+
ops.push_back("push:nothing");
|
677
|
+
}
|
678
|
+
// Results from transport
|
679
|
+
std::vector<std::string> queued;
|
680
|
+
if (server_initial_metadata_state_ ==
|
681
|
+
ServerInitialMetadataState::kReceivedButNotSet) {
|
682
|
+
queued.push_back("initial_metadata");
|
683
|
+
}
|
684
|
+
if (queued_trailing_metadata_) queued.push_back("trailing_metadata");
|
685
|
+
if (!queued.empty()) {
|
686
|
+
ops.push_back(absl::StrCat("queued:", absl::StrJoin(queued, ",")));
|
687
|
+
}
|
688
|
+
// Send message
|
689
|
+
std::string send_message_state = SendMessageString();
|
690
|
+
if (send_message_state != "WAITING") {
|
691
|
+
ops.push_back(absl::StrCat("send_message:", send_message_state));
|
692
|
+
}
|
693
|
+
// Receive message
|
694
|
+
std::string recv_message_state = RecvMessageString();
|
695
|
+
if (recv_message_state != "IDLE") {
|
696
|
+
ops.push_back(absl::StrCat("recv_message:", recv_message_state));
|
697
|
+
}
|
698
|
+
return absl::StrJoin(ops, " ");
|
699
|
+
}
|
700
|
+
|
701
|
+
std::string SendMessageString() const ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_) {
|
702
|
+
return Match(
|
703
|
+
send_message_state_, [](Idle) -> std::string { return "IDLE"; },
|
704
|
+
[](Closed) -> std::string { return "CLOSED"; },
|
705
|
+
[](const PipeReceiver<MessageHandle>::NextType&) -> std::string {
|
706
|
+
return "WAITING";
|
707
|
+
},
|
708
|
+
[](SendMessageToTransport) -> std::string { return "SENDING"; });
|
709
|
+
}
|
710
|
+
|
711
|
+
std::string RecvMessageString() const ABSL_EXCLUSIVE_LOCKS_REQUIRED(mu_) {
|
712
|
+
return Match(
|
713
|
+
recv_message_state_, [](Idle) -> std::string { return "IDLE"; },
|
714
|
+
[](Closed) -> std::string { return "CLOSED"; },
|
715
|
+
[](const PendingReceiveMessage&) -> std::string { return "WAITING"; },
|
716
|
+
[](const absl::optional<MessageHandle>& message) -> std::string {
|
717
|
+
return absl::StrCat(
|
718
|
+
"READY:", message.has_value()
|
719
|
+
? absl::StrCat((*message)->payload()->Length(), "b")
|
720
|
+
: "EOS");
|
721
|
+
},
|
722
|
+
[](const PipeSender<MessageHandle>::PushType&) -> std::string {
|
723
|
+
return "PUSHING";
|
724
|
+
});
|
725
|
+
}
|
726
|
+
|
727
|
+
Mutex mu_;
|
728
|
+
bool requested_metadata_ = false;
|
729
|
+
bool push_metadata_ ABSL_GUARDED_BY(mu_) = false;
|
730
|
+
bool push_send_message_ ABSL_GUARDED_BY(mu_) = false;
|
731
|
+
bool push_recv_message_ ABSL_GUARDED_BY(mu_) = false;
|
732
|
+
bool scheduled_push_ ABSL_GUARDED_BY(mu_) = false;
|
733
|
+
ServerInitialMetadataState server_initial_metadata_state_
|
734
|
+
ABSL_GUARDED_BY(mu_) = ServerInitialMetadataState::kNotReceived;
|
735
|
+
bool queued_trailing_metadata_ ABSL_GUARDED_BY(mu_) = false;
|
736
|
+
bool finished_ ABSL_GUARDED_BY(mu_) = false;
|
737
|
+
CallContext* const call_context_{GetContext<CallContext>()};
|
738
|
+
Waker initial_metadata_waker_ ABSL_GUARDED_BY(mu_);
|
739
|
+
Waker trailing_metadata_waker_ ABSL_GUARDED_BY(mu_);
|
740
|
+
Waker send_message_waker_ ABSL_GUARDED_BY(mu_);
|
741
|
+
Waker recv_message_waker_ ABSL_GUARDED_BY(mu_);
|
742
|
+
grpc_transport* const transport_;
|
743
|
+
grpc_stream_refcount stream_refcount_;
|
744
|
+
StreamPtr stream_;
|
745
|
+
Latch<ServerMetadata*>* server_initial_metadata_latch_;
|
746
|
+
PipeReceiver<MessageHandle>* client_to_server_messages_;
|
747
|
+
PipeSender<MessageHandle>* server_to_client_messages_;
|
748
|
+
MessageHandle message_to_send_ ABSL_GUARDED_BY(mu_);
|
749
|
+
absl::variant<Idle, Closed, PipeReceiver<MessageHandle>::NextType,
|
750
|
+
SendMessageToTransport>
|
751
|
+
send_message_state_ ABSL_GUARDED_BY(mu_);
|
752
|
+
struct PendingReceiveMessage {
|
753
|
+
absl::optional<SliceBuffer> payload;
|
754
|
+
uint32_t flags;
|
755
|
+
bool received = false;
|
756
|
+
};
|
757
|
+
absl::variant<Idle, PendingReceiveMessage, Closed,
|
758
|
+
PipeSender<MessageHandle>::PushType>
|
759
|
+
recv_message_state_ ABSL_GUARDED_BY(mu_);
|
760
|
+
grpc_closure recv_initial_metadata_ready_ =
|
761
|
+
MakeMemberClosure<ClientStream, &ClientStream::RecvInitialMetadataReady>(
|
762
|
+
this, DEBUG_LOCATION);
|
763
|
+
grpc_closure recv_trailing_metadata_ready_ =
|
764
|
+
MakeMemberClosure<ClientStream, &ClientStream::RecvTrailingMetadataReady>(
|
765
|
+
this, DEBUG_LOCATION);
|
766
|
+
grpc_closure push_ = MakeMemberClosure<ClientStream, &ClientStream::Push>(
|
767
|
+
this, DEBUG_LOCATION);
|
768
|
+
ClientMetadataHandle client_initial_metadata_;
|
769
|
+
ClientMetadataHandle client_trailing_metadata_;
|
770
|
+
ServerMetadataHandle server_initial_metadata_;
|
771
|
+
ServerMetadataHandle server_trailing_metadata_;
|
772
|
+
grpc_transport_stream_op_batch metadata_;
|
773
|
+
grpc_closure metadata_batch_done_ =
|
774
|
+
MakeMemberClosure<ClientStream, &ClientStream::MetadataBatchDone>(
|
775
|
+
this, DEBUG_LOCATION);
|
776
|
+
grpc_transport_stream_op_batch send_message_;
|
777
|
+
grpc_closure send_message_batch_done_ =
|
778
|
+
MakeMemberClosure<ClientStream, &ClientStream::SendMessageBatchDone>(
|
779
|
+
this, DEBUG_LOCATION);
|
780
|
+
grpc_closure recv_message_batch_done_ =
|
781
|
+
MakeMemberClosure<ClientStream, &ClientStream::RecvMessageBatchDone>(
|
782
|
+
this, DEBUG_LOCATION);
|
783
|
+
grpc_transport_stream_op_batch recv_message_;
|
784
|
+
grpc_transport_stream_op_batch_payload batch_payload_{
|
785
|
+
GetContext<grpc_call_context_element>()};
|
786
|
+
grpc_closure stream_destroyed_ =
|
787
|
+
MakeMemberClosure<ClientStream, &ClientStream::StreamDestroyed>(
|
788
|
+
this, DEBUG_LOCATION);
|
229
789
|
};
|
230
790
|
|
791
|
+
class ClientConnectedCallPromise {
|
792
|
+
public:
|
793
|
+
ClientConnectedCallPromise(grpc_transport* transport, CallArgs call_args)
|
794
|
+
: impl_(GetContext<Arena>()->New<ClientStream>(transport,
|
795
|
+
std::move(call_args))) {}
|
796
|
+
|
797
|
+
ClientConnectedCallPromise(const ClientConnectedCallPromise&) = delete;
|
798
|
+
ClientConnectedCallPromise& operator=(const ClientConnectedCallPromise&) =
|
799
|
+
delete;
|
800
|
+
ClientConnectedCallPromise(ClientConnectedCallPromise&& other) noexcept
|
801
|
+
: impl_(std::exchange(other.impl_, nullptr)) {}
|
802
|
+
ClientConnectedCallPromise& operator=(
|
803
|
+
ClientConnectedCallPromise&& other) noexcept {
|
804
|
+
impl_ = std::move(other.impl_);
|
805
|
+
return *this;
|
806
|
+
}
|
807
|
+
|
808
|
+
static ArenaPromise<ServerMetadataHandle> Make(grpc_transport* transport,
|
809
|
+
CallArgs call_args) {
|
810
|
+
return ClientConnectedCallPromise(transport, std::move(call_args));
|
811
|
+
}
|
812
|
+
|
813
|
+
Poll<ServerMetadataHandle> operator()() { return impl_->PollOnce(); }
|
814
|
+
|
815
|
+
private:
|
816
|
+
OrphanablePtr<ClientStream> impl_;
|
817
|
+
};
|
818
|
+
|
819
|
+
template <ArenaPromise<ServerMetadataHandle> (*make_call_promise)(
|
820
|
+
grpc_transport*, CallArgs)>
|
821
|
+
grpc_channel_filter MakeConnectedFilter() {
|
822
|
+
// Create a vtable that contains both the legacy call methods (for filter
|
823
|
+
// stack based calls) and the new promise based method for creating promise
|
824
|
+
// based calls (the latter iff make_call_promise != nullptr).
|
825
|
+
// In this way the filter can be inserted into either kind of channel stack,
|
826
|
+
// and only if all the filters in the stack are promise based will the call
|
827
|
+
// be promise based.
|
828
|
+
return {
|
829
|
+
connected_channel_start_transport_stream_op_batch,
|
830
|
+
make_call_promise == nullptr
|
831
|
+
? nullptr
|
832
|
+
: +[](grpc_channel_element* elem, CallArgs call_args,
|
833
|
+
NextPromiseFactory) {
|
834
|
+
grpc_transport* transport =
|
835
|
+
static_cast<channel_data*>(elem->channel_data)->transport;
|
836
|
+
return make_call_promise(transport, std::move(call_args));
|
837
|
+
},
|
838
|
+
connected_channel_start_transport_op,
|
839
|
+
sizeof(call_data),
|
840
|
+
connected_channel_init_call_elem,
|
841
|
+
set_pollset_or_pollset_set,
|
842
|
+
connected_channel_destroy_call_elem,
|
843
|
+
sizeof(channel_data),
|
844
|
+
connected_channel_init_channel_elem,
|
845
|
+
+[](grpc_channel_stack* channel_stack, grpc_channel_element* elem) {
|
846
|
+
/* HACK(ctiller): increase call stack size for the channel to make space
|
847
|
+
for channel data. We need a cleaner (but performant) way to do this,
|
848
|
+
and I'm not sure what that is yet.
|
849
|
+
This is only "safe" because call stacks place no additional data
|
850
|
+
after the last call element, and the last call element MUST be the
|
851
|
+
connected channel. */
|
852
|
+
channel_stack->call_stack_size += grpc_transport_stream_size(
|
853
|
+
static_cast<channel_data*>(elem->channel_data)->transport);
|
854
|
+
},
|
855
|
+
connected_channel_destroy_channel_elem,
|
856
|
+
connected_channel_get_channel_info,
|
857
|
+
"connected",
|
858
|
+
};
|
859
|
+
}
|
860
|
+
|
861
|
+
ArenaPromise<ServerMetadataHandle> MakeTransportCallPromise(
|
862
|
+
grpc_transport* transport, CallArgs call_args) {
|
863
|
+
return transport->vtable->make_call_promise(transport, std::move(call_args));
|
864
|
+
}
|
865
|
+
|
866
|
+
const grpc_channel_filter kPromiseBasedTransportFilter =
|
867
|
+
MakeConnectedFilter<MakeTransportCallPromise>();
|
868
|
+
|
869
|
+
const grpc_channel_filter kClientEmulatedFilter =
|
870
|
+
MakeConnectedFilter<ClientConnectedCallPromise::Make>();
|
871
|
+
|
872
|
+
const grpc_channel_filter kNoPromiseFilter = MakeConnectedFilter<nullptr>();
|
873
|
+
|
874
|
+
} // namespace
|
875
|
+
} // namespace grpc_core
|
876
|
+
|
231
877
|
bool grpc_add_connected_filter(grpc_core::ChannelStackBuilder* builder) {
|
232
878
|
grpc_transport* t = builder->transport();
|
233
879
|
GPR_ASSERT(t != nullptr);
|
234
|
-
|
880
|
+
// Choose the right vtable for the connected filter.
|
881
|
+
// We can't know promise based call or not here (that decision needs the
|
882
|
+
// collaboration of all of the filters on the channel, and we don't want
|
883
|
+
// ordering constraints on when we add filters).
|
884
|
+
// We can know if this results in a promise based call how we'll create our
|
885
|
+
// promise (if indeed we can), and so that is the choice made here.
|
886
|
+
if (t->vtable->make_call_promise != nullptr) {
|
887
|
+
// Option 1, and our ideal: the transport supports promise based calls, and
|
888
|
+
// so we simply use the transport directly.
|
889
|
+
builder->AppendFilter(&grpc_core::kPromiseBasedTransportFilter);
|
890
|
+
} else if (grpc_channel_stack_type_is_client(builder->channel_stack_type())) {
|
891
|
+
// Option 2: the transport does not support promise based calls, but we're
|
892
|
+
// on the client and so we have an implementation that we can use to convert
|
893
|
+
// to batches.
|
894
|
+
builder->AppendFilter(&grpc_core::kClientEmulatedFilter);
|
895
|
+
} else {
|
896
|
+
// Option 3: the transport does not support promise based calls, and we're
|
897
|
+
// on the server so we can't construct promise based calls just yet.
|
898
|
+
builder->AppendFilter(&grpc_core::kNoPromiseFilter);
|
899
|
+
}
|
235
900
|
return true;
|
236
901
|
}
|
237
|
-
|
238
|
-
grpc_stream* grpc_connected_channel_get_stream(grpc_call_element* elem) {
|
239
|
-
call_data* calld = static_cast<call_data*>(elem->call_data);
|
240
|
-
return TRANSPORT_STREAM_FROM_CALL_DATA(calld);
|
241
|
-
}
|