grpc 1.50.0.pre1-x86_64-linux → 1.51.0-x86_64-linux

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.

Files changed (464) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +131 -42
  3. data/include/grpc/event_engine/event_engine.h +10 -3
  4. data/include/grpc/event_engine/slice_buffer.h +17 -0
  5. data/include/grpc/grpc.h +0 -10
  6. data/include/grpc/impl/codegen/grpc_types.h +1 -5
  7. data/include/grpc/impl/codegen/port_platform.h +0 -3
  8. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +19 -13
  9. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +1 -0
  10. data/src/core/ext/filters/client_channel/backup_poller.cc +3 -3
  11. data/src/core/ext/filters/client_channel/channel_connectivity.cc +7 -5
  12. data/src/core/ext/filters/client_channel/client_channel.cc +120 -140
  13. data/src/core/ext/filters/client_channel/client_channel.h +3 -4
  14. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +0 -2
  15. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
  16. data/src/core/ext/filters/client_channel/client_channel_service_config.cc +153 -0
  17. data/src/core/ext/filters/client_channel/{resolver_result_parsing.h → client_channel_service_config.h} +26 -23
  18. data/src/core/ext/filters/client_channel/connector.h +1 -1
  19. data/src/core/ext/filters/client_channel/dynamic_filters.cc +20 -47
  20. data/src/core/ext/filters/client_channel/dynamic_filters.h +7 -8
  21. data/src/core/ext/filters/client_channel/health/health_check_client.cc +3 -4
  22. data/src/core/ext/filters/client_channel/http_proxy.cc +0 -1
  23. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +3 -4
  24. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +5 -0
  25. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +8 -7
  26. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +35 -44
  27. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -1
  28. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +1 -3
  29. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +3 -4
  30. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +1 -1
  31. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +41 -29
  32. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +2 -2
  33. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +9 -11
  34. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +15 -12
  35. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +8 -10
  36. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +26 -27
  37. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +7 -9
  38. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +44 -26
  39. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +17 -27
  40. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_attributes.cc +42 -0
  41. data/src/core/ext/filters/client_channel/lb_policy/xds/{xds.h → xds_attributes.h} +15 -17
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +13 -7
  43. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +48 -47
  44. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +40 -126
  45. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +364 -0
  46. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +9 -9
  47. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +23 -32
  48. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +1 -2
  49. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +22 -23
  50. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +50 -52
  51. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +1 -1
  52. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +2 -4
  53. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +1 -3
  54. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +34 -26
  55. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +3 -4
  56. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +4 -7
  57. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +63 -46
  58. data/src/core/ext/filters/client_channel/retry_filter.cc +80 -102
  59. data/src/core/ext/filters/client_channel/retry_service_config.cc +192 -234
  60. data/src/core/ext/filters/client_channel/retry_service_config.h +20 -23
  61. data/src/core/ext/filters/client_channel/retry_throttle.cc +8 -8
  62. data/src/core/ext/filters/client_channel/retry_throttle.h +8 -7
  63. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +2 -2
  64. data/src/core/ext/filters/client_channel/subchannel.cc +21 -25
  65. data/src/core/ext/filters/client_channel/subchannel.h +2 -2
  66. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +11 -12
  67. data/src/core/ext/filters/deadline/deadline_filter.cc +13 -14
  68. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +1 -1
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +0 -4
  70. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +118 -0
  71. data/src/core/ext/filters/fault_injection/{service_config_parser.h → fault_injection_service_config_parser.h} +20 -12
  72. data/src/core/ext/filters/http/client/http_client_filter.cc +16 -16
  73. data/src/core/ext/filters/http/client_authority_filter.cc +1 -1
  74. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +13 -13
  75. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +34 -34
  76. data/src/core/ext/filters/http/server/http_server_filter.cc +26 -25
  77. data/src/core/ext/filters/message_size/message_size_filter.cc +86 -117
  78. data/src/core/ext/filters/message_size/message_size_filter.h +22 -15
  79. data/src/core/ext/filters/rbac/rbac_filter.cc +12 -12
  80. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +728 -530
  81. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +4 -3
  82. data/src/core/ext/filters/server_config_selector/server_config_selector.h +1 -1
  83. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +6 -7
  84. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +17 -21
  85. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +57 -72
  86. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +5 -5
  87. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -1
  88. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +212 -253
  89. data/src/core/ext/transport/chttp2/transport/flow_control.cc +42 -11
  90. data/src/core/ext/transport/chttp2/transport/flow_control.h +4 -3
  91. data/src/core/ext/transport/chttp2/transport/frame_data.cc +16 -15
  92. data/src/core/ext/transport/chttp2/transport/frame_data.h +1 -1
  93. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +13 -13
  94. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -3
  95. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +10 -7
  96. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +15 -17
  97. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +5 -4
  98. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +5 -6
  99. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +1 -1
  100. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -1
  101. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +31 -39
  102. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +7 -6
  103. data/src/core/ext/transport/chttp2/transport/internal.h +24 -8
  104. data/src/core/ext/transport/chttp2/transport/parsing.cc +51 -52
  105. data/src/core/ext/transport/chttp2/transport/varint.cc +2 -3
  106. data/src/core/ext/transport/chttp2/transport/varint.h +11 -8
  107. data/src/core/ext/transport/chttp2/transport/writing.cc +16 -16
  108. data/src/core/ext/transport/inproc/inproc_transport.cc +97 -115
  109. data/src/core/ext/xds/certificate_provider_store.cc +4 -4
  110. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +4 -7
  111. data/src/core/ext/xds/xds_api.cc +15 -68
  112. data/src/core/ext/xds/xds_api.h +3 -7
  113. data/src/core/ext/xds/xds_bootstrap.h +0 -1
  114. data/src/core/ext/xds/xds_bootstrap_grpc.cc +3 -12
  115. data/src/core/ext/xds/xds_bootstrap_grpc.h +16 -1
  116. data/src/core/ext/xds/xds_certificate_provider.cc +22 -25
  117. data/src/core/ext/xds/xds_channel_stack_modifier.cc +0 -1
  118. data/src/core/ext/xds/xds_client.cc +122 -90
  119. data/src/core/ext/xds/xds_client.h +7 -2
  120. data/src/core/ext/xds/xds_client_grpc.cc +5 -24
  121. data/src/core/ext/xds/xds_cluster.cc +291 -183
  122. data/src/core/ext/xds/xds_cluster.h +11 -15
  123. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +32 -29
  124. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +35 -16
  125. data/src/core/ext/xds/xds_common_types.cc +208 -141
  126. data/src/core/ext/xds/xds_common_types.h +19 -13
  127. data/src/core/ext/xds/xds_endpoint.cc +214 -129
  128. data/src/core/ext/xds/xds_endpoint.h +4 -7
  129. data/src/core/ext/xds/xds_http_fault_filter.cc +56 -43
  130. data/src/core/ext/xds/xds_http_fault_filter.h +13 -21
  131. data/src/core/ext/xds/xds_http_filters.cc +60 -73
  132. data/src/core/ext/xds/xds_http_filters.h +67 -19
  133. data/src/core/ext/xds/xds_http_rbac_filter.cc +152 -207
  134. data/src/core/ext/xds/xds_http_rbac_filter.h +12 -15
  135. data/src/core/ext/xds/xds_lb_policy_registry.cc +122 -169
  136. data/src/core/ext/xds/xds_lb_policy_registry.h +10 -11
  137. data/src/core/ext/xds/xds_listener.cc +459 -417
  138. data/src/core/ext/xds/xds_listener.h +43 -47
  139. data/src/core/ext/xds/xds_resource_type.h +3 -11
  140. data/src/core/ext/xds/xds_resource_type_impl.h +8 -13
  141. data/src/core/ext/xds/xds_route_config.cc +94 -80
  142. data/src/core/ext/xds/xds_route_config.h +10 -10
  143. data/src/core/ext/xds/xds_routing.cc +2 -1
  144. data/src/core/ext/xds/xds_routing.h +2 -0
  145. data/src/core/ext/xds/xds_server_config_fetcher.cc +109 -94
  146. data/src/core/ext/xds/xds_transport_grpc.cc +4 -5
  147. data/src/core/lib/address_utils/parse_address.cc +11 -10
  148. data/src/core/lib/channel/channel_args.h +16 -1
  149. data/src/core/lib/channel/channel_stack.cc +23 -20
  150. data/src/core/lib/channel/channel_stack.h +17 -4
  151. data/src/core/lib/channel/channel_stack_builder.cc +4 -7
  152. data/src/core/lib/channel/channel_stack_builder.h +14 -6
  153. data/src/core/lib/channel/channel_stack_builder_impl.cc +25 -7
  154. data/src/core/lib/channel/channel_stack_builder_impl.h +2 -0
  155. data/src/core/lib/channel/channel_trace.cc +4 -5
  156. data/src/core/lib/channel/channelz.cc +1 -1
  157. data/src/core/lib/channel/connected_channel.cc +695 -35
  158. data/src/core/lib/channel/connected_channel.h +0 -4
  159. data/src/core/lib/channel/promise_based_filter.cc +1004 -140
  160. data/src/core/lib/channel/promise_based_filter.h +364 -87
  161. data/src/core/lib/compression/message_compress.cc +5 -5
  162. data/src/core/lib/debug/event_log.cc +88 -0
  163. data/src/core/lib/debug/event_log.h +81 -0
  164. data/src/core/lib/debug/histogram_view.cc +69 -0
  165. data/src/core/lib/{slice/slice_refcount.cc → debug/histogram_view.h} +15 -13
  166. data/src/core/lib/debug/stats.cc +22 -119
  167. data/src/core/lib/debug/stats.h +29 -35
  168. data/src/core/lib/debug/stats_data.cc +224 -73
  169. data/src/core/lib/debug/stats_data.h +263 -122
  170. data/src/core/lib/event_engine/common_closures.h +71 -0
  171. data/src/core/lib/event_engine/default_event_engine.cc +38 -15
  172. data/src/core/lib/event_engine/default_event_engine.h +15 -3
  173. data/src/core/lib/event_engine/default_event_engine_factory.cc +2 -4
  174. data/src/core/lib/event_engine/memory_allocator.cc +1 -1
  175. data/src/core/lib/event_engine/poller.h +10 -4
  176. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +618 -0
  177. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +129 -0
  178. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +901 -0
  179. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +97 -0
  180. data/src/core/lib/event_engine/posix_engine/event_poller.h +111 -0
  181. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +74 -0
  182. data/src/core/lib/event_engine/{executor/threaded_executor.cc → posix_engine/event_poller_posix_default.h} +13 -16
  183. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +77 -0
  184. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +179 -0
  185. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +267 -0
  186. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +73 -0
  187. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +1270 -0
  188. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +682 -0
  189. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +453 -18
  190. data/src/core/lib/event_engine/posix_engine/posix_engine.h +148 -24
  191. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +80 -0
  192. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +1081 -0
  193. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +361 -0
  194. data/src/core/lib/event_engine/posix_engine/timer.h +9 -8
  195. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +57 -194
  196. data/src/core/lib/event_engine/posix_engine/timer_manager.h +21 -49
  197. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +301 -0
  198. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +179 -0
  199. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +126 -0
  200. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +45 -0
  201. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +151 -0
  202. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +45 -0
  203. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +76 -0
  204. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +67 -0
  205. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +37 -0
  206. data/src/core/lib/event_engine/slice.cc +7 -6
  207. data/src/core/lib/event_engine/slice_buffer.cc +2 -2
  208. data/src/core/lib/event_engine/thread_pool.cc +106 -25
  209. data/src/core/lib/event_engine/thread_pool.h +32 -9
  210. data/src/core/lib/event_engine/windows/win_socket.cc +7 -7
  211. data/src/core/lib/event_engine/windows/windows_engine.cc +18 -12
  212. data/src/core/lib/event_engine/windows/windows_engine.h +8 -4
  213. data/src/core/lib/experiments/config.cc +1 -1
  214. data/src/core/lib/experiments/experiments.cc +13 -2
  215. data/src/core/lib/experiments/experiments.h +8 -1
  216. data/src/core/lib/gpr/cpu_linux.cc +6 -2
  217. data/src/core/lib/gpr/log_linux.cc +3 -4
  218. data/src/core/lib/gpr/string.h +1 -1
  219. data/src/core/lib/gpr/tmpfile_posix.cc +3 -2
  220. data/src/core/lib/gprpp/load_file.cc +75 -0
  221. data/src/core/lib/gprpp/load_file.h +33 -0
  222. data/src/core/lib/gprpp/per_cpu.h +46 -0
  223. data/src/core/lib/gprpp/stat_posix.cc +5 -4
  224. data/src/core/lib/gprpp/stat_windows.cc +3 -2
  225. data/src/core/lib/gprpp/status_helper.h +1 -3
  226. data/src/core/lib/gprpp/strerror.cc +41 -0
  227. data/src/core/{ext/xds/xds_resource_type.cc → lib/gprpp/strerror.h} +9 -13
  228. data/src/core/lib/gprpp/thd_windows.cc +1 -2
  229. data/src/core/lib/gprpp/time.cc +3 -4
  230. data/src/core/lib/gprpp/time.h +13 -2
  231. data/src/core/lib/gprpp/validation_errors.h +18 -1
  232. data/src/core/lib/http/httpcli.cc +40 -44
  233. data/src/core/lib/http/httpcli.h +6 -5
  234. data/src/core/lib/http/httpcli_security_connector.cc +4 -6
  235. data/src/core/lib/http/parser.cc +54 -65
  236. data/src/core/lib/iomgr/buffer_list.cc +105 -116
  237. data/src/core/lib/iomgr/buffer_list.h +60 -44
  238. data/src/core/lib/iomgr/call_combiner.cc +11 -10
  239. data/src/core/lib/iomgr/call_combiner.h +3 -4
  240. data/src/core/lib/iomgr/cfstream_handle.cc +13 -16
  241. data/src/core/lib/iomgr/closure.h +49 -5
  242. data/src/core/lib/iomgr/combiner.cc +2 -2
  243. data/src/core/lib/iomgr/endpoint.h +1 -1
  244. data/src/core/lib/iomgr/endpoint_cfstream.cc +26 -25
  245. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -2
  246. data/src/core/lib/iomgr/error.cc +27 -42
  247. data/src/core/lib/iomgr/error.h +22 -152
  248. data/src/core/lib/iomgr/ev_apple.cc +4 -4
  249. data/src/core/lib/iomgr/ev_epoll1_linux.cc +26 -25
  250. data/src/core/lib/iomgr/ev_poll_posix.cc +27 -31
  251. data/src/core/lib/iomgr/exec_ctx.cc +3 -4
  252. data/src/core/lib/iomgr/exec_ctx.h +2 -3
  253. data/src/core/lib/iomgr/executor.cc +1 -2
  254. data/src/core/lib/iomgr/internal_errqueue.cc +3 -1
  255. data/src/core/lib/iomgr/iocp_windows.cc +1 -0
  256. data/src/core/lib/iomgr/iomgr_posix.cc +2 -2
  257. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +2 -1
  258. data/src/core/lib/iomgr/iomgr_windows.cc +2 -1
  259. data/src/core/lib/iomgr/load_file.cc +5 -9
  260. data/src/core/lib/iomgr/lockfree_event.cc +10 -10
  261. data/src/core/lib/iomgr/pollset_windows.cc +4 -4
  262. data/src/core/lib/iomgr/python_util.h +2 -2
  263. data/src/core/lib/iomgr/resolve_address.cc +8 -3
  264. data/src/core/lib/iomgr/resolve_address.h +3 -4
  265. data/src/core/lib/iomgr/resolve_address_impl.h +1 -1
  266. data/src/core/lib/iomgr/resolve_address_posix.cc +14 -25
  267. data/src/core/lib/iomgr/resolve_address_posix.h +1 -2
  268. data/src/core/lib/iomgr/resolve_address_windows.cc +14 -17
  269. data/src/core/lib/iomgr/resolve_address_windows.h +1 -2
  270. data/src/core/lib/iomgr/socket_utils_common_posix.cc +30 -29
  271. data/src/core/lib/iomgr/socket_utils_posix.cc +1 -0
  272. data/src/core/lib/iomgr/socket_utils_posix.h +2 -2
  273. data/src/core/lib/iomgr/socket_windows.cc +2 -2
  274. data/src/core/lib/iomgr/tcp_client_cfstream.cc +6 -10
  275. data/src/core/lib/iomgr/tcp_client_posix.cc +31 -35
  276. data/src/core/lib/iomgr/tcp_client_windows.cc +8 -12
  277. data/src/core/lib/iomgr/tcp_posix.cc +92 -108
  278. data/src/core/lib/iomgr/tcp_server_posix.cc +34 -34
  279. data/src/core/lib/iomgr/tcp_server_utils_posix.h +1 -1
  280. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +18 -21
  281. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +12 -13
  282. data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +1 -1
  283. data/src/core/lib/iomgr/tcp_server_windows.cc +26 -29
  284. data/src/core/lib/iomgr/tcp_windows.cc +27 -34
  285. data/src/core/lib/iomgr/timer.h +8 -8
  286. data/src/core/lib/iomgr/timer_generic.cc +9 -15
  287. data/src/core/lib/iomgr/unix_sockets_posix.cc +2 -4
  288. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +4 -3
  289. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +10 -8
  290. data/src/core/lib/json/json_channel_args.h +42 -0
  291. data/src/core/lib/json/json_object_loader.cc +7 -2
  292. data/src/core/lib/json/json_object_loader.h +22 -0
  293. data/src/core/lib/json/json_util.cc +5 -5
  294. data/src/core/lib/json/json_util.h +4 -4
  295. data/src/core/lib/load_balancing/lb_policy.cc +1 -1
  296. data/src/core/lib/load_balancing/lb_policy.h +4 -0
  297. data/src/core/lib/load_balancing/subchannel_interface.h +0 -7
  298. data/src/core/lib/matchers/matchers.cc +3 -4
  299. data/src/core/lib/promise/activity.cc +16 -2
  300. data/src/core/lib/promise/activity.h +38 -15
  301. data/src/core/lib/promise/arena_promise.h +80 -51
  302. data/src/core/lib/promise/context.h +13 -6
  303. data/src/core/lib/promise/detail/basic_seq.h +9 -28
  304. data/src/core/lib/promise/detail/promise_factory.h +58 -10
  305. data/src/core/lib/promise/detail/status.h +28 -0
  306. data/src/core/lib/promise/detail/switch.h +1455 -0
  307. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +3 -1
  308. data/src/core/lib/promise/for_each.h +129 -0
  309. data/src/core/lib/promise/loop.h +7 -5
  310. data/src/core/lib/promise/map_pipe.h +87 -0
  311. data/src/core/lib/promise/pipe.cc +19 -0
  312. data/src/core/lib/promise/pipe.h +505 -0
  313. data/src/core/lib/promise/poll.h +13 -0
  314. data/src/core/lib/promise/seq.h +3 -5
  315. data/src/core/lib/promise/sleep.cc +5 -4
  316. data/src/core/lib/promise/sleep.h +1 -2
  317. data/src/core/lib/promise/try_concurrently.h +341 -0
  318. data/src/core/lib/promise/try_seq.h +10 -13
  319. data/src/core/lib/resolver/server_address.cc +1 -0
  320. data/src/core/lib/resolver/server_address.h +1 -3
  321. data/src/core/lib/resource_quota/api.cc +0 -1
  322. data/src/core/lib/resource_quota/arena.cc +19 -0
  323. data/src/core/lib/resource_quota/arena.h +89 -0
  324. data/src/core/lib/resource_quota/memory_quota.cc +1 -0
  325. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +1 -3
  326. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +4 -2
  327. data/src/core/lib/security/authorization/matchers.cc +25 -22
  328. data/src/core/lib/security/authorization/rbac_policy.cc +2 -3
  329. data/src/core/lib/security/context/security_context.h +10 -0
  330. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +3 -4
  331. data/src/core/lib/security/credentials/composite/composite_credentials.cc +1 -1
  332. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +77 -55
  333. data/src/core/lib/security/credentials/external/aws_request_signer.cc +4 -3
  334. data/src/core/lib/security/credentials/external/external_account_credentials.cc +40 -51
  335. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +17 -21
  336. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +21 -25
  337. data/src/core/lib/security/credentials/fake/fake_credentials.cc +1 -0
  338. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -24
  339. data/src/core/lib/security/credentials/iam/iam_credentials.cc +1 -0
  340. data/src/core/lib/security/credentials/jwt/json_token.cc +1 -2
  341. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +1 -1
  342. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +5 -5
  343. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +24 -30
  344. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +6 -5
  345. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +3 -3
  346. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +19 -27
  347. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +4 -11
  348. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +29 -41
  349. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +1 -1
  350. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +6 -11
  351. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +8 -15
  352. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +2 -2
  353. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +2 -6
  354. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +1 -4
  355. data/src/core/lib/security/security_connector/local/local_security_connector.cc +7 -11
  356. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +9 -14
  357. data/src/core/lib/security/security_connector/ssl_utils.cc +5 -7
  358. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -27
  359. data/src/core/lib/security/transport/client_auth_filter.cc +1 -1
  360. data/src/core/lib/security/transport/secure_endpoint.cc +26 -28
  361. data/src/core/lib/security/transport/security_handshaker.cc +53 -53
  362. data/src/core/lib/security/transport/server_auth_filter.cc +21 -21
  363. data/src/core/lib/security/transport/tsi_error.cc +6 -3
  364. data/src/core/lib/security/util/json_util.cc +4 -5
  365. data/src/core/lib/service_config/service_config.h +1 -1
  366. data/src/core/lib/service_config/service_config_impl.cc +111 -158
  367. data/src/core/lib/service_config/service_config_impl.h +14 -17
  368. data/src/core/lib/service_config/service_config_parser.cc +14 -31
  369. data/src/core/lib/service_config/service_config_parser.h +14 -10
  370. data/src/core/lib/slice/b64.cc +2 -2
  371. data/src/core/lib/slice/slice.cc +7 -1
  372. data/src/core/lib/slice/slice.h +19 -6
  373. data/src/core/lib/slice/slice_buffer.cc +13 -14
  374. data/src/core/lib/slice/slice_internal.h +13 -21
  375. data/src/core/lib/slice/slice_refcount.h +34 -19
  376. data/src/core/lib/surface/byte_buffer.cc +3 -4
  377. data/src/core/lib/surface/byte_buffer_reader.cc +4 -4
  378. data/src/core/lib/surface/call.cc +1366 -239
  379. data/src/core/lib/surface/call.h +44 -0
  380. data/src/core/lib/surface/call_details.cc +3 -3
  381. data/src/core/lib/surface/call_trace.cc +113 -0
  382. data/src/core/lib/surface/call_trace.h +30 -0
  383. data/src/core/lib/surface/channel.cc +44 -49
  384. data/src/core/lib/surface/channel.h +9 -1
  385. data/src/core/lib/surface/channel_ping.cc +1 -1
  386. data/src/core/lib/surface/channel_stack_type.cc +4 -0
  387. data/src/core/lib/surface/channel_stack_type.h +2 -0
  388. data/src/core/lib/surface/completion_queue.cc +38 -52
  389. data/src/core/lib/surface/init.cc +8 -39
  390. data/src/core/lib/surface/init_internally.h +8 -0
  391. data/src/core/lib/surface/lame_client.cc +10 -8
  392. data/src/core/lib/surface/server.cc +48 -70
  393. data/src/core/lib/surface/server.h +3 -4
  394. data/src/core/lib/surface/validate_metadata.cc +11 -12
  395. data/src/core/lib/surface/version.cc +2 -2
  396. data/src/core/lib/transport/connectivity_state.cc +2 -2
  397. data/src/core/lib/transport/error_utils.cc +34 -28
  398. data/src/core/lib/transport/error_utils.h +3 -3
  399. data/src/core/lib/transport/handshaker.cc +14 -14
  400. data/src/core/lib/transport/handshaker.h +1 -1
  401. data/src/core/lib/transport/handshaker_factory.h +26 -0
  402. data/src/core/lib/transport/handshaker_registry.cc +8 -2
  403. data/src/core/lib/transport/handshaker_registry.h +3 -4
  404. data/src/core/lib/transport/http_connect_handshaker.cc +23 -24
  405. data/src/core/lib/transport/metadata_batch.h +17 -1
  406. data/src/core/lib/transport/parsed_metadata.cc +2 -6
  407. data/src/core/lib/transport/tcp_connect_handshaker.cc +15 -20
  408. data/src/core/lib/transport/transport.cc +63 -17
  409. data/src/core/lib/transport/transport.h +64 -68
  410. data/src/core/lib/transport/transport_impl.h +1 -1
  411. data/src/core/lib/transport/transport_op_string.cc +7 -6
  412. data/src/core/plugin_registry/grpc_plugin_registry.cc +6 -10
  413. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +2 -14
  414. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +10 -10
  415. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +8 -8
  416. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -1
  417. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +7 -7
  418. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +7 -6
  419. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +1 -1
  420. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +5 -5
  421. data/src/core/tsi/fake_transport_security.cc +3 -3
  422. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +7 -3
  423. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +1 -1
  424. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +6 -2
  425. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +0 -2
  426. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +0 -3
  427. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  428. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  429. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  430. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  431. data/src/ruby/lib/grpc/grpc_c.so +0 -0
  432. data/src/ruby/lib/grpc/version.rb +1 -1
  433. data/src/ruby/spec/channel_spec.rb +0 -43
  434. data/src/ruby/spec/generic/active_call_spec.rb +12 -3
  435. data/third_party/abseil-cpp/absl/cleanup/cleanup.h +140 -0
  436. data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +100 -0
  437. data/third_party/zlib/compress.c +3 -3
  438. data/third_party/zlib/crc32.c +21 -12
  439. data/third_party/zlib/deflate.c +112 -106
  440. data/third_party/zlib/deflate.h +2 -2
  441. data/third_party/zlib/gzlib.c +1 -1
  442. data/third_party/zlib/gzread.c +3 -5
  443. data/third_party/zlib/gzwrite.c +1 -1
  444. data/third_party/zlib/infback.c +10 -7
  445. data/third_party/zlib/inflate.c +5 -2
  446. data/third_party/zlib/inftrees.c +2 -2
  447. data/third_party/zlib/inftrees.h +1 -1
  448. data/third_party/zlib/trees.c +61 -62
  449. data/third_party/zlib/uncompr.c +2 -2
  450. data/third_party/zlib/zconf.h +16 -3
  451. data/third_party/zlib/zlib.h +10 -10
  452. data/third_party/zlib/zutil.c +9 -7
  453. data/third_party/zlib/zutil.h +1 -0
  454. metadata +57 -20
  455. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +0 -188
  456. data/src/core/ext/filters/fault_injection/service_config_parser.cc +0 -187
  457. data/src/core/lib/event_engine/executor/threaded_executor.h +0 -44
  458. data/src/core/lib/gpr/murmur_hash.cc +0 -82
  459. data/src/core/lib/gpr/murmur_hash.h +0 -29
  460. data/src/core/lib/gpr/tls.h +0 -156
  461. data/src/core/lib/promise/call_push_pull.h +0 -148
  462. data/src/core/lib/slice/slice_api.cc +0 -39
  463. data/src/core/lib/slice/slice_buffer_api.cc +0 -35
  464. 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
- GRPC_ERROR_REF(error), state->reason);
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 ? GRPC_ERROR_NONE
160
- : GRPC_ERROR_CREATE_FROM_STATIC_STRING(
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 GRPC_ERROR_NONE;
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
- const grpc_channel_filter grpc_connected_filter = {
207
- connected_channel_start_transport_stream_op_batch,
208
- nullptr,
209
- connected_channel_start_transport_op,
210
- sizeof(call_data),
211
- connected_channel_init_call_elem,
212
- set_pollset_or_pollset_set,
213
- connected_channel_destroy_call_elem,
214
- sizeof(channel_data),
215
- connected_channel_init_channel_elem,
216
- [](grpc_channel_stack* channel_stack, grpc_channel_element* elem) {
217
- /* HACK(ctiller): increase call stack size for the channel to make space
218
- for channel data. We need a cleaner (but performant) way to do this,
219
- and I'm not sure what that is yet.
220
- This is only "safe" because call stacks place no additional data after
221
- the last call element, and the last call element MUST be the connected
222
- channel. */
223
- channel_stack->call_stack_size += grpc_transport_stream_size(
224
- static_cast<channel_data*>(elem->channel_data)->transport);
225
- },
226
- connected_channel_destroy_channel_elem,
227
- connected_channel_get_channel_info,
228
- "connected",
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
- builder->AppendFilter(&grpc_connected_filter);
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
- }