grpc 1.72.0 → 1.78.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2090) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +153 -54
  3. data/include/grpc/create_channel_from_endpoint.h +54 -0
  4. data/include/grpc/credentials.h +41 -8
  5. data/include/grpc/event_engine/event_engine.h +182 -8
  6. data/include/grpc/event_engine/internal/write_event.h +34 -0
  7. data/include/grpc/event_engine/memory_allocator.h +2 -0
  8. data/include/grpc/event_engine/memory_request.h +2 -0
  9. data/include/grpc/grpc_posix.h +20 -1
  10. data/include/grpc/impl/channel_arg_names.h +24 -13
  11. data/include/grpc/impl/compression_types.h +3 -2
  12. data/include/grpc/impl/slice_type.h +1 -1
  13. data/include/grpc/module.modulemap +1 -0
  14. data/include/grpc/support/json.h +27 -21
  15. data/include/grpc/support/metrics.h +7 -1
  16. data/include/grpc/support/port_platform.h +8 -5
  17. data/src/core/call/call_filters.cc +5 -5
  18. data/src/core/call/call_filters.h +239 -56
  19. data/src/core/call/call_spine.cc +1 -1
  20. data/src/core/call/call_spine.h +56 -32
  21. data/src/core/call/channelz_context.h +30 -0
  22. data/src/core/call/client_call.cc +53 -14
  23. data/src/core/call/client_call.h +6 -3
  24. data/src/core/call/filter_fusion.h +1230 -0
  25. data/src/core/call/interception_chain.h +8 -11
  26. data/src/core/call/metadata.cc +22 -0
  27. data/src/core/call/metadata.h +41 -2
  28. data/src/core/call/metadata_batch.cc +49 -55
  29. data/src/core/call/metadata_batch.h +10 -9
  30. data/src/core/call/metadata_info.cc +1 -1
  31. data/src/core/call/parsed_metadata.h +2 -2
  32. data/src/core/call/request_buffer.cc +1 -1
  33. data/src/core/call/security_context.cc +2 -2
  34. data/src/core/call/security_context.h +1 -1
  35. data/src/core/call/server_call.cc +5 -5
  36. data/src/core/call/server_call.h +6 -4
  37. data/src/core/call/simple_slice_based_metadata.h +1 -1
  38. data/src/core/call/status_util.cc +1 -1
  39. data/src/core/channelz/channel_trace.cc +218 -112
  40. data/src/core/channelz/channel_trace.h +390 -65
  41. data/src/core/channelz/channelz.cc +483 -192
  42. data/src/core/channelz/channelz.h +523 -78
  43. data/src/core/channelz/channelz_registry.cc +239 -195
  44. data/src/core/channelz/channelz_registry.h +261 -21
  45. data/src/core/channelz/property_list.cc +371 -0
  46. data/src/core/channelz/property_list.h +215 -0
  47. data/src/core/channelz/text_encode.cc +66 -0
  48. data/src/core/channelz/text_encode.h +29 -0
  49. data/src/core/channelz/v2tov1/convert.cc +694 -0
  50. data/src/core/channelz/v2tov1/convert.h +58 -0
  51. data/src/core/channelz/v2tov1/legacy_api.cc +431 -0
  52. data/src/core/channelz/v2tov1/legacy_api.h +32 -0
  53. data/src/core/channelz/v2tov1/property_list.cc +119 -0
  54. data/src/core/channelz/v2tov1/property_list.h +52 -0
  55. data/src/core/channelz/ztrace_collector.h +489 -0
  56. data/src/core/client_channel/backup_poller.cc +19 -5
  57. data/src/core/client_channel/buffered_call.cc +140 -0
  58. data/src/core/client_channel/buffered_call.h +104 -0
  59. data/src/core/client_channel/client_channel.cc +179 -129
  60. data/src/core/client_channel/client_channel.h +8 -11
  61. data/src/core/client_channel/client_channel_factory.h +1 -1
  62. data/src/core/client_channel/client_channel_filter.cc +449 -719
  63. data/src/core/client_channel/client_channel_filter.h +57 -152
  64. data/src/core/client_channel/client_channel_internal.h +8 -4
  65. data/src/core/client_channel/client_channel_service_config.cc +43 -3
  66. data/src/core/client_channel/client_channel_service_config.h +12 -1
  67. data/src/core/client_channel/config_selector.h +13 -7
  68. data/src/core/client_channel/connector.h +2 -3
  69. data/src/core/client_channel/dynamic_filters.cc +10 -11
  70. data/src/core/client_channel/dynamic_filters.h +1 -1
  71. data/src/core/client_channel/global_subchannel_pool.cc +42 -15
  72. data/src/core/client_channel/global_subchannel_pool.h +19 -13
  73. data/src/core/client_channel/lb_metadata.h +1 -1
  74. data/src/core/client_channel/load_balanced_call_destination.cc +9 -10
  75. data/src/core/client_channel/load_balanced_call_destination.h +1 -1
  76. data/src/core/client_channel/local_subchannel_pool.cc +4 -4
  77. data/src/core/client_channel/retry_filter.cc +23 -29
  78. data/src/core/client_channel/retry_filter.h +13 -10
  79. data/src/core/client_channel/retry_filter_legacy_call_data.cc +16 -17
  80. data/src/core/client_channel/retry_filter_legacy_call_data.h +7 -9
  81. data/src/core/client_channel/retry_interceptor.cc +30 -44
  82. data/src/core/client_channel/retry_interceptor.h +18 -17
  83. data/src/core/client_channel/retry_service_config.cc +3 -3
  84. data/src/core/client_channel/retry_service_config.h +1 -1
  85. data/src/core/client_channel/retry_throttle.cc +46 -61
  86. data/src/core/client_channel/retry_throttle.h +17 -39
  87. data/src/core/client_channel/subchannel.cc +174 -55
  88. data/src/core/client_channel/subchannel.h +36 -16
  89. data/src/core/client_channel/subchannel_pool_interface.cc +7 -8
  90. data/src/core/client_channel/subchannel_pool_interface.h +12 -2
  91. data/src/core/client_channel/subchannel_stream_client.cc +5 -5
  92. data/src/core/client_channel/subchannel_stream_client.h +3 -3
  93. data/src/core/config/config_vars.cc +50 -3
  94. data/src/core/config/config_vars.h +34 -0
  95. data/src/core/config/core_configuration.cc +56 -14
  96. data/src/core/config/core_configuration.h +116 -11
  97. data/src/core/config/load_config.cc +13 -1
  98. data/src/core/config/load_config.h +2 -0
  99. data/src/core/credentials/call/call_credentials.h +4 -4
  100. data/src/core/credentials/call/call_creds_registry.h +125 -0
  101. data/src/core/credentials/call/call_creds_registry_init.cc +91 -0
  102. data/src/core/credentials/call/call_creds_util.cc +7 -6
  103. data/src/core/credentials/call/composite/composite_call_credentials.cc +6 -6
  104. data/src/core/credentials/call/composite/composite_call_credentials.h +1 -1
  105. data/src/core/credentials/call/external/aws_external_account_credentials.cc +9 -9
  106. data/src/core/credentials/call/external/aws_external_account_credentials.h +1 -1
  107. data/src/core/credentials/call/external/aws_request_signer.cc +3 -2
  108. data/src/core/credentials/call/external/external_account_credentials.cc +12 -12
  109. data/src/core/credentials/call/external/external_account_credentials.h +1 -1
  110. data/src/core/credentials/call/external/file_external_account_credentials.cc +3 -3
  111. data/src/core/credentials/call/external/file_external_account_credentials.h +1 -1
  112. data/src/core/credentials/call/external/url_external_account_credentials.cc +9 -9
  113. data/src/core/credentials/call/external/url_external_account_credentials.h +1 -1
  114. data/src/core/credentials/call/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +26 -115
  115. data/src/core/credentials/call/gcp_service_account_identity/gcp_service_account_identity_credentials.h +1 -8
  116. data/src/core/credentials/call/iam/iam_credentials.cc +6 -6
  117. data/src/core/credentials/call/iam/iam_credentials.h +1 -1
  118. data/src/core/credentials/call/json_util.cc +1 -1
  119. data/src/core/credentials/call/jwt/json_token.cc +7 -7
  120. data/src/core/credentials/call/jwt/jwt_credentials.cc +5 -5
  121. data/src/core/credentials/call/jwt/jwt_credentials.h +4 -4
  122. data/src/core/credentials/call/jwt/jwt_verifier.cc +23 -22
  123. data/src/core/credentials/call/jwt_token_file/jwt_token_file_call_credentials.cc +86 -0
  124. data/src/core/credentials/call/jwt_token_file/jwt_token_file_call_credentials.h +74 -0
  125. data/src/core/credentials/call/jwt_util.cc +70 -0
  126. data/src/core/credentials/call/jwt_util.h +32 -0
  127. data/src/core/credentials/call/oauth2/oauth2_credentials.cc +53 -74
  128. data/src/core/credentials/call/oauth2/oauth2_credentials.h +3 -9
  129. data/src/core/credentials/call/plugin/plugin_credentials.cc +6 -6
  130. data/src/core/credentials/call/plugin/plugin_credentials.h +2 -2
  131. data/src/core/credentials/call/token_fetcher/token_fetcher_credentials.cc +46 -0
  132. data/src/core/credentials/call/token_fetcher/token_fetcher_credentials.h +32 -3
  133. data/src/core/credentials/transport/alts/alts_credentials.cc +5 -0
  134. data/src/core/credentials/transport/alts/alts_security_connector.cc +17 -14
  135. data/src/core/credentials/transport/alts/check_gcp_environment_no_op.cc +1 -1
  136. data/src/core/credentials/transport/alts/check_gcp_environment_windows.cc +2 -0
  137. data/src/core/credentials/transport/alts/grpc_alts_credentials_client_options.cc +23 -3
  138. data/src/core/credentials/transport/alts/grpc_alts_credentials_options.cc +10 -1
  139. data/src/core/credentials/transport/alts/grpc_alts_credentials_options.h +31 -0
  140. data/src/core/credentials/transport/alts/grpc_alts_credentials_server_options.cc +8 -3
  141. data/src/core/credentials/transport/channel_creds_registry.h +1 -1
  142. data/src/core/credentials/transport/channel_creds_registry_init.cc +5 -3
  143. data/src/core/credentials/transport/composite/composite_channel_credentials.cc +7 -7
  144. data/src/core/credentials/transport/composite/composite_channel_credentials.h +1 -1
  145. data/src/core/credentials/transport/fake/fake_credentials.cc +1 -1
  146. data/src/core/credentials/transport/fake/fake_credentials.h +1 -1
  147. data/src/core/credentials/transport/fake/fake_security_connector.cc +7 -7
  148. data/src/core/credentials/transport/google_default/credentials_generic.cc +2 -2
  149. data/src/core/credentials/transport/google_default/google_default_credentials.cc +151 -39
  150. data/src/core/credentials/transport/google_default/google_default_credentials.h +0 -2
  151. data/src/core/credentials/transport/insecure/insecure_security_connector.cc +3 -3
  152. data/src/core/credentials/transport/insecure/insecure_security_connector.h +2 -2
  153. data/src/core/credentials/transport/local/local_security_connector.cc +13 -13
  154. data/src/core/credentials/transport/security_connector.cc +6 -6
  155. data/src/core/credentials/transport/security_connector.h +2 -2
  156. data/src/core/credentials/transport/ssl/ssl_credentials.cc +16 -17
  157. data/src/core/credentials/transport/ssl/ssl_credentials.h +2 -2
  158. data/src/core/credentials/transport/ssl/ssl_security_connector.cc +57 -22
  159. data/src/core/credentials/transport/ssl/ssl_security_connector.h +2 -1
  160. data/src/core/credentials/transport/tls/certificate_provider_factory.h +1 -1
  161. data/src/core/credentials/transport/tls/certificate_provider_registry.cc +2 -2
  162. data/src/core/credentials/transport/tls/certificate_provider_registry.h +1 -1
  163. data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.cc +52 -47
  164. data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.h +21 -10
  165. data/src/core/credentials/transport/tls/grpc_tls_certificate_match.cc +1 -1
  166. data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.cc +103 -61
  167. data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.h +20 -7
  168. data/src/core/credentials/transport/tls/grpc_tls_certificate_verifier.cc +3 -3
  169. data/src/core/credentials/transport/tls/grpc_tls_certificate_verifier.h +4 -4
  170. data/src/core/credentials/transport/tls/grpc_tls_credentials_options.cc +18 -18
  171. data/src/core/credentials/transport/tls/grpc_tls_crl_provider.cc +5 -5
  172. data/src/core/credentials/transport/tls/grpc_tls_crl_provider.h +3 -3
  173. data/src/core/credentials/transport/tls/load_system_roots_supported.cc +2 -1
  174. data/src/core/credentials/transport/tls/spiffe_utils.cc +373 -0
  175. data/src/core/credentials/transport/tls/spiffe_utils.h +171 -0
  176. data/src/core/credentials/transport/tls/ssl_utils.cc +46 -22
  177. data/src/core/credentials/transport/tls/ssl_utils.h +11 -4
  178. data/src/core/credentials/transport/tls/tls_credentials.cc +3 -1
  179. data/src/core/credentials/transport/tls/tls_security_connector.cc +28 -42
  180. data/src/core/credentials/transport/tls/tls_security_connector.h +15 -15
  181. data/src/core/credentials/transport/transport_credentials.cc +3 -3
  182. data/src/core/credentials/transport/transport_credentials.h +4 -4
  183. data/src/core/credentials/transport/xds/xds_credentials.cc +5 -8
  184. data/src/core/credentials/transport/xds/xds_credentials.h +1 -1
  185. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +3 -4
  186. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +4 -1
  187. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +12 -7
  188. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +2 -2
  189. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +7 -7
  190. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +6 -3
  191. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +1 -1
  192. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.cc +10 -10
  193. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.h +22 -19
  194. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.h +1 -1
  195. data/src/core/ext/filters/http/client/http_client_filter.cc +9 -12
  196. data/src/core/ext/filters/http/client/http_client_filter.h +4 -1
  197. data/src/core/ext/filters/http/client_authority_filter.cc +5 -8
  198. data/src/core/ext/filters/http/client_authority_filter.h +4 -1
  199. data/src/core/ext/filters/http/http_filters_plugin.cc +1 -1
  200. data/src/core/ext/filters/http/message_compress/compression_filter.cc +19 -19
  201. data/src/core/ext/filters/http/message_compress/compression_filter.h +61 -9
  202. data/src/core/ext/filters/http/server/http_server_filter.cc +7 -10
  203. data/src/core/ext/filters/http/server/http_server_filter.h +22 -7
  204. data/src/core/ext/filters/message_size/message_size_filter.cc +6 -6
  205. data/src/core/ext/filters/message_size/message_size_filter.h +8 -2
  206. data/src/core/ext/filters/rbac/rbac_filter.cc +2 -2
  207. data/src/core/ext/filters/rbac/rbac_filter.h +4 -1
  208. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +3 -3
  209. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +1 -1
  210. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +17 -19
  211. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +13 -2
  212. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +1 -1
  213. data/src/core/ext/transport/chttp2/alpn/alpn.cc +2 -2
  214. data/src/core/ext/transport/chttp2/chttp2_plugin.cc +40 -0
  215. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +176 -178
  216. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +5 -3
  217. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +63 -990
  218. data/src/core/ext/transport/chttp2/server/chttp2_server.h +6 -3
  219. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +6 -6
  220. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +6 -6
  221. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +490 -202
  222. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +10 -8
  223. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +1239 -3514
  224. data/src/core/ext/transport/chttp2/transport/decode_huff.h +1008 -1486
  225. data/src/core/ext/transport/chttp2/transport/flow_control.cc +43 -7
  226. data/src/core/ext/transport/chttp2/transport/flow_control.h +247 -83
  227. data/src/core/ext/transport/chttp2/transport/flow_control_manager.h +105 -0
  228. data/src/core/ext/transport/chttp2/transport/frame.cc +472 -123
  229. data/src/core/ext/transport/chttp2/transport/frame.h +170 -12
  230. data/src/core/ext/transport/chttp2/transport/frame_data.cc +15 -5
  231. data/src/core/ext/transport/chttp2/transport/frame_data.h +3 -1
  232. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +20 -8
  233. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +5 -3
  234. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +8 -6
  235. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +18 -11
  236. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +3 -1
  237. data/src/core/ext/transport/chttp2/transport/frame_security.cc +1 -1
  238. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +33 -24
  239. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +14 -11
  240. data/src/core/ext/transport/chttp2/transport/goaway.cc +129 -0
  241. data/src/core/ext/transport/chttp2/transport/goaway.h +350 -0
  242. data/src/core/ext/transport/chttp2/transport/header_assembler.h +430 -0
  243. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +10 -3
  244. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +10 -6
  245. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +8 -8
  246. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +3 -3
  247. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +5 -5
  248. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +35 -35
  249. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +10 -8
  250. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +19 -13
  251. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +13 -2
  252. data/src/core/ext/transport/chttp2/transport/http2_client_transport.cc +2076 -0
  253. data/src/core/ext/transport/chttp2/transport/http2_client_transport.h +723 -0
  254. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +12 -39
  255. data/src/core/ext/transport/chttp2/transport/http2_settings.h +71 -29
  256. data/src/core/ext/transport/chttp2/transport/http2_settings_manager.cc +62 -0
  257. data/src/core/ext/transport/chttp2/transport/http2_settings_manager.h +143 -0
  258. data/src/core/ext/transport/chttp2/transport/http2_settings_promises.h +417 -0
  259. data/{third_party/abseil-cpp/absl/strings/cord_buffer.cc → src/core/ext/transport/chttp2/transport/http2_stats_collector.cc} +14 -14
  260. data/src/core/ext/transport/chttp2/transport/http2_stats_collector.h +33 -0
  261. data/src/core/ext/transport/chttp2/transport/http2_status.h +369 -1
  262. data/src/core/ext/transport/chttp2/transport/http2_transport.cc +428 -0
  263. data/src/core/ext/transport/chttp2/transport/http2_transport.h +251 -0
  264. data/src/core/ext/transport/chttp2/transport/http2_ztrace_collector.h +323 -0
  265. data/src/core/ext/transport/chttp2/transport/incoming_metadata_tracker.h +128 -0
  266. data/src/core/ext/transport/chttp2/transport/internal.h +72 -26
  267. data/src/core/ext/transport/chttp2/transport/internal_channel_arg_names.h +24 -0
  268. data/src/core/ext/transport/chttp2/transport/keepalive.cc +112 -0
  269. data/src/core/ext/transport/chttp2/transport/keepalive.h +142 -0
  270. data/src/core/ext/transport/chttp2/transport/message_assembler.h +194 -0
  271. data/src/core/ext/transport/chttp2/transport/parsing.cc +64 -48
  272. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +2 -2
  273. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +21 -2
  274. data/src/core/ext/transport/chttp2/transport/ping_promise.cc +194 -0
  275. data/src/core/ext/transport/chttp2/transport/ping_promise.h +237 -0
  276. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +16 -19
  277. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +17 -0
  278. data/src/core/ext/transport/chttp2/transport/security_frame.cc +31 -0
  279. data/src/core/ext/transport/chttp2/transport/security_frame.h +32 -0
  280. data/src/core/ext/transport/chttp2/transport/stream.h +287 -0
  281. data/src/core/ext/transport/chttp2/transport/stream_data_queue.h +875 -0
  282. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +46 -8
  283. data/src/core/ext/transport/chttp2/transport/transport_common.cc +35 -0
  284. data/src/core/ext/transport/chttp2/transport/transport_common.h +84 -0
  285. data/src/core/ext/transport/chttp2/transport/varint.h +2 -2
  286. data/src/core/ext/transport/chttp2/transport/writable_streams.h +372 -0
  287. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +2 -2
  288. data/src/core/ext/transport/chttp2/transport/writing.cc +105 -66
  289. data/src/core/ext/transport/inproc/inproc_transport.cc +16 -5
  290. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +17 -10
  291. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +4 -0
  292. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +12 -0
  293. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +12 -22
  294. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +12 -22
  295. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +28 -22
  296. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +12 -0
  297. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +24 -67
  298. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +4 -0
  299. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +4 -0
  300. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +29 -31
  301. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +2 -2
  302. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +12 -0
  303. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +4 -0
  304. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +8 -0
  305. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +4 -0
  306. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +4 -0
  307. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +0 -23
  308. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +8 -0
  309. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +8 -0
  310. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +12 -0
  311. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +20 -0
  312. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +12 -0
  313. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +8 -22
  314. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +0 -23
  315. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +64 -66
  316. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +4 -0
  317. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +12 -0
  318. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +4 -0
  319. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +4 -0
  320. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +4 -95
  321. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +8 -0
  322. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +4 -0
  323. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +4 -0
  324. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +28 -0
  325. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +4 -0
  326. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +4 -0
  327. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +4 -0
  328. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +12 -0
  329. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +8 -0
  330. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +8 -36
  331. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +4 -0
  332. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +4 -0
  333. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +4 -0
  334. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +4 -0
  335. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +4 -0
  336. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +4 -0
  337. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +4 -0
  338. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +4 -0
  339. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +4 -0
  340. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +8 -0
  341. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +8 -0
  342. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +4 -0
  343. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +4 -0
  344. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +4 -0
  345. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +8 -44
  346. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +12 -40
  347. data/src/core/ext/upb-gen/google/api/http.upb.h +4 -0
  348. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +193 -20
  349. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +59 -21
  350. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +4 -0
  351. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +4 -22
  352. data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb.h +4959 -0
  353. data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb_minitable.c +1111 -0
  354. data/src/core/ext/upb-gen/src/proto/grpc/channelz/channelz.upb_minitable.h +108 -0
  355. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/channelz.upb.h +571 -0
  356. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/channelz.upb_minitable.c +120 -0
  357. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/channelz.upb_minitable.h +36 -0
  358. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/promise.upb.h +1272 -0
  359. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/promise.upb_minitable.c +312 -0
  360. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/promise.upb_minitable.h +50 -0
  361. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb.h +1072 -0
  362. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb_minitable.c +230 -0
  363. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/property_list.upb_minitable.h +44 -0
  364. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/service.upb.h +740 -0
  365. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/service.upb_minitable.c +218 -0
  366. data/src/core/ext/upb-gen/src/proto/grpc/channelz/v2/service.upb_minitable.h +46 -0
  367. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +0 -18
  368. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +196 -104
  369. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +40 -32
  370. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +154 -0
  371. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +40 -2
  372. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.h +4 -0
  373. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +8 -0
  374. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +0 -18
  375. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +0 -36
  376. data/src/core/ext/upb-gen/validate/validate.upb.h +12 -0
  377. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +4 -0
  378. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb.h +0 -18
  379. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +8 -0
  380. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +0 -54
  381. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +20 -22
  382. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +4 -0
  383. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +4 -0
  384. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +4 -0
  385. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.c +123 -62
  386. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.h +5 -1
  387. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.c +200 -101
  388. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.h +5 -1
  389. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.c +152 -77
  390. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.h +5 -1
  391. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.c +524 -255
  392. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.h +5 -1
  393. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.c +44 -23
  394. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.h +5 -1
  395. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.c +66 -34
  396. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.h +5 -1
  397. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.c +54 -28
  398. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.h +5 -1
  399. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.c +46 -25
  400. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.h +5 -1
  401. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.c +47 -25
  402. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.h +5 -1
  403. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +256 -126
  404. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.h +5 -1
  405. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.c +50 -28
  406. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.h +5 -1
  407. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.c +55 -28
  408. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.h +5 -1
  409. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.c +34 -18
  410. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.h +5 -1
  411. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +414 -206
  412. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.h +5 -1
  413. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +831 -413
  414. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +5 -1
  415. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +143 -73
  416. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +5 -1
  417. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +1132 -557
  418. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +5 -1
  419. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +63 -34
  420. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.h +5 -1
  421. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +255 -127
  422. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.h +5 -1
  423. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +363 -178
  424. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.h +5 -1
  425. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +227 -114
  426. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.h +5 -1
  427. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.c +57 -31
  428. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.h +5 -1
  429. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +596 -295
  430. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +5 -1
  431. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +271 -137
  432. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.h +5 -1
  433. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.c +56 -30
  434. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.h +5 -1
  435. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.c +45 -25
  436. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.h +5 -1
  437. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.c +59 -31
  438. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.h +5 -1
  439. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +438 -217
  440. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.h +5 -1
  441. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +441 -221
  442. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.h +5 -1
  443. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +55 -30
  444. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +5 -1
  445. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +57 -31
  446. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.h +5 -1
  447. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +619 -303
  448. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.h +5 -1
  449. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.c +70 -36
  450. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.h +5 -1
  451. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.c +62 -33
  452. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.h +5 -1
  453. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.c +47 -25
  454. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.h +5 -1
  455. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.c +97 -49
  456. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.h +5 -1
  457. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +97 -51
  458. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +5 -1
  459. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.c +51 -27
  460. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.h +5 -1
  461. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +147 -76
  462. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.h +5 -1
  463. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +230 -116
  464. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +5 -1
  465. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +277 -138
  466. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +5 -1
  467. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.c +48 -26
  468. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.h +5 -1
  469. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +388 -197
  470. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.h +5 -1
  471. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.c +304 -153
  472. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.h +5 -1
  473. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +173 -90
  474. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.h +5 -1
  475. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.c +90 -47
  476. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.h +5 -1
  477. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.c +98 -51
  478. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.h +5 -1
  479. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.c +196 -99
  480. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.h +5 -1
  481. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.c +237 -118
  482. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.h +5 -1
  483. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +418 -210
  484. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.h +5 -1
  485. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +194 -99
  486. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.h +5 -1
  487. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +2003 -973
  488. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.h +5 -1
  489. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.c +101 -53
  490. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.h +5 -1
  491. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +352 -176
  492. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.h +5 -1
  493. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +79 -42
  494. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +5 -1
  495. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +67 -37
  496. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.h +5 -1
  497. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.c +63 -34
  498. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.h +5 -1
  499. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.c +88 -47
  500. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.h +5 -1
  501. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +80 -43
  502. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.h +5 -1
  503. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.c +53 -29
  504. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.h +5 -1
  505. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.c +86 -46
  506. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.h +5 -1
  507. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.c +55 -32
  508. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.h +5 -1
  509. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.c +91 -49
  510. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.h +5 -1
  511. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +105 -55
  512. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.h +5 -1
  513. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +775 -379
  514. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.h +5 -1
  515. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +52 -28
  516. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +5 -1
  517. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +134 -68
  518. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +5 -1
  519. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +189 -96
  520. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +5 -1
  521. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +116 -61
  522. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +5 -1
  523. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +112 -58
  524. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +5 -1
  525. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +160 -82
  526. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.h +5 -1
  527. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +75 -39
  528. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +5 -1
  529. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +1161 -570
  530. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -1
  531. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +52 -28
  532. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +5 -1
  533. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.c +55 -29
  534. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.h +5 -1
  535. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +48 -26
  536. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +5 -1
  537. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +390 -194
  538. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -1
  539. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +126 -65
  540. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +5 -1
  541. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +498 -246
  542. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +5 -1
  543. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +74 -38
  544. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +5 -1
  545. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.c +221 -110
  546. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.h +5 -1
  547. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.c +68 -36
  548. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.h +5 -1
  549. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.c +378 -187
  550. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.h +5 -1
  551. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.c +100 -52
  552. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.h +5 -1
  553. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +257 -129
  554. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.h +5 -1
  555. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.c +44 -24
  556. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.h +5 -1
  557. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.c +68 -35
  558. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.h +5 -1
  559. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.c +38 -20
  560. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.h +5 -1
  561. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.c +59 -32
  562. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.h +5 -1
  563. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.c +65 -34
  564. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.h +5 -1
  565. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.c +72 -38
  566. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.h +5 -1
  567. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.c +57 -31
  568. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.h +5 -1
  569. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.c +52 -29
  570. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.h +5 -1
  571. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.c +51 -28
  572. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.h +5 -1
  573. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.c +89 -47
  574. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.h +5 -1
  575. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.c +37 -20
  576. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.h +5 -1
  577. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +89 -47
  578. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.h +5 -1
  579. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.c +67 -35
  580. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.h +5 -1
  581. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +112 -58
  582. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +5 -1
  583. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.c +110 -56
  584. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.h +5 -1
  585. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.c +123 -62
  586. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.h +5 -1
  587. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.c +59 -31
  588. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.h +5 -1
  589. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.c +30 -16
  590. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.h +5 -1
  591. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.c +143 -72
  592. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.h +5 -1
  593. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.c +61 -32
  594. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.h +5 -1
  595. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.c +51 -27
  596. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.h +5 -1
  597. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.c +85 -45
  598. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.h +5 -1
  599. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.c +35 -19
  600. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.h +5 -1
  601. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.c +44 -23
  602. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.h +5 -1
  603. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.c +61 -33
  604. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.h +5 -1
  605. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.c +35 -19
  606. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.h +5 -1
  607. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +272 -133
  608. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.h +5 -1
  609. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +315 -154
  610. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +5 -1
  611. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.c +64 -33
  612. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.h +5 -1
  613. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.c +35 -19
  614. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.h +5 -1
  615. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.c +26 -15
  616. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.h +5 -1
  617. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +1106 -508
  618. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +10 -1
  619. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.c +28 -16
  620. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.h +5 -1
  621. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.c +23 -13
  622. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.h +5 -1
  623. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.c +69 -35
  624. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.h +5 -1
  625. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.c +29 -16
  626. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.h +5 -1
  627. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.c +51 -26
  628. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.h +5 -1
  629. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.c +32 -17
  630. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.h +5 -1
  631. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/channelz.upbdefs.c +716 -0
  632. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/channelz.upbdefs.h +227 -0
  633. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/channelz.upbdefs.c +80 -0
  634. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/channelz.upbdefs.h +47 -0
  635. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/promise.upbdefs.c +175 -0
  636. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/promise.upbdefs.h +82 -0
  637. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/property_list.upbdefs.c +133 -0
  638. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/property_list.upbdefs.h +67 -0
  639. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/service.upbdefs.c +129 -0
  640. data/src/core/ext/upbdefs-gen/src/proto/grpc/channelz/v2/service.upbdefs.h +72 -0
  641. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +161 -79
  642. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +5 -1
  643. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.c +84 -42
  644. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.h +5 -1
  645. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.c +48 -26
  646. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.h +5 -1
  647. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.c +26 -14
  648. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.h +5 -1
  649. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.c +50 -26
  650. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.h +5 -1
  651. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.c +36 -19
  652. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.h +5 -1
  653. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.c +538 -261
  654. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.h +5 -1
  655. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.c +86 -43
  656. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.h +5 -1
  657. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.c +49 -26
  658. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.h +5 -1
  659. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.c +27 -15
  660. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.h +5 -1
  661. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.c +87 -44
  662. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.h +5 -1
  663. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.c +37 -20
  664. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.h +5 -1
  665. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.c +30 -17
  666. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.h +5 -1
  667. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.c +41 -23
  668. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.h +5 -1
  669. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.c +62 -33
  670. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.h +5 -1
  671. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.c +36 -19
  672. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.h +5 -1
  673. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.c +36 -20
  674. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.h +5 -1
  675. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.c +42 -23
  676. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.h +5 -1
  677. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.c +76 -39
  678. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.h +5 -1
  679. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.c +45 -24
  680. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.h +5 -1
  681. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +41 -23
  682. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.h +5 -1
  683. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.c +53 -29
  684. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.h +5 -1
  685. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.c +29 -16
  686. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.h +5 -1
  687. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.c +58 -32
  688. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.h +5 -1
  689. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.c +207 -103
  690. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.h +5 -1
  691. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.c +95 -49
  692. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.h +5 -1
  693. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.c +38 -20
  694. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.h +5 -1
  695. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.c +60 -31
  696. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.h +5 -1
  697. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.c +67 -36
  698. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.h +5 -1
  699. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.c +31 -17
  700. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.h +5 -1
  701. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.c +31 -17
  702. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.h +5 -1
  703. data/src/core/filter/auth/auth_filters.h +9 -28
  704. data/src/core/filter/auth/client_auth_filter.cc +2 -120
  705. data/src/core/filter/auth/server_auth_filter.cc +5 -5
  706. data/src/core/filter/blackboard.h +2 -2
  707. data/src/core/filter/filter_args.h +46 -22
  708. data/src/core/filter/fused_filters.cc +154 -0
  709. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.cc +2 -2
  710. data/src/core/handshaker/handshaker.cc +31 -22
  711. data/src/core/handshaker/handshaker.h +5 -2
  712. data/src/core/handshaker/http_connect/http_connect_handshaker.cc +8 -6
  713. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +19 -34
  714. data/src/core/handshaker/http_connect/http_proxy_mapper.h +1 -1
  715. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.cc +1 -1
  716. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.h +1 -1
  717. data/src/core/handshaker/proxy_mapper.h +1 -1
  718. data/src/core/handshaker/proxy_mapper_registry.h +1 -1
  719. data/src/core/handshaker/security/legacy_secure_endpoint.cc +597 -0
  720. data/src/core/handshaker/security/pipelined_secure_endpoint.cc +988 -0
  721. data/src/core/handshaker/security/secure_endpoint.cc +851 -314
  722. data/src/core/handshaker/security/secure_endpoint.h +25 -0
  723. data/src/core/handshaker/security/security_handshaker.cc +18 -12
  724. data/src/core/handshaker/security/security_handshaker.h +1 -1
  725. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +13 -7
  726. data/src/core/lib/address_utils/parse_address.cc +5 -5
  727. data/src/core/lib/address_utils/parse_address.h +2 -2
  728. data/src/core/lib/address_utils/sockaddr_utils.cc +9 -9
  729. data/src/core/lib/address_utils/sockaddr_utils.h +1 -1
  730. data/src/core/lib/channel/channel_args.cc +16 -1
  731. data/src/core/lib/channel/channel_args.h +9 -2
  732. data/src/core/lib/channel/channel_stack.cc +61 -29
  733. data/src/core/lib/channel/channel_stack.h +23 -7
  734. data/src/core/lib/channel/channel_stack_builder.cc +8 -4
  735. data/src/core/lib/channel/channel_stack_builder.h +10 -9
  736. data/src/core/lib/channel/channel_stack_builder_impl.cc +8 -13
  737. data/src/core/lib/channel/channel_stack_builder_impl.h +3 -8
  738. data/src/core/lib/channel/connected_channel.cc +4 -4
  739. data/src/core/lib/channel/promise_based_filter.cc +147 -97
  740. data/src/core/lib/channel/promise_based_filter.h +753 -328
  741. data/src/core/lib/compression/compression_internal.cc +6 -6
  742. data/src/core/lib/compression/compression_internal.h +1 -1
  743. data/src/core/lib/compression/message_compress.cc +8 -8
  744. data/src/core/lib/debug/trace.cc +2 -5
  745. data/src/core/lib/debug/trace.h +10 -0
  746. data/src/core/lib/debug/trace_flags.cc +4 -4
  747. data/src/core/lib/debug/trace_flags.h +2 -2
  748. data/src/core/lib/debug/trace_impl.h +0 -1
  749. data/src/core/lib/event_engine/ares_resolver.cc +185 -64
  750. data/src/core/lib/event_engine/ares_resolver.h +55 -7
  751. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +20 -10
  752. data/src/core/lib/event_engine/cf_engine/cf_engine.h +2 -4
  753. data/src/core/lib/event_engine/cf_engine/cfsocket_listener.cc +263 -0
  754. data/src/core/lib/event_engine/cf_engine/cfsocket_listener.h +107 -0
  755. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +37 -9
  756. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +23 -7
  757. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +4 -4
  758. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +3 -3
  759. data/src/core/lib/event_engine/channel_args_endpoint_config.h +1 -1
  760. data/src/core/lib/event_engine/default_event_engine.cc +1 -1
  761. data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -1
  762. data/src/core/lib/event_engine/endpoint_channel_arg_wrapper.cc +40 -0
  763. data/src/core/lib/event_engine/endpoint_channel_arg_wrapper.h +60 -0
  764. data/src/core/lib/event_engine/event_engine.cc +7 -0
  765. data/src/core/lib/event_engine/extensions/blocking_dns.h +46 -0
  766. data/src/core/lib/event_engine/extensions/channelz.h +66 -0
  767. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +1 -1
  768. data/src/core/lib/event_engine/extensions/supports_fd.h +5 -5
  769. data/src/core/lib/event_engine/extensions/tcp_trace.h +10 -3
  770. data/src/core/lib/event_engine/grpc_polled_fd.h +6 -1
  771. data/src/core/lib/event_engine/memory_allocator_factory.h +1 -1
  772. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +147 -177
  773. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +21 -23
  774. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +104 -145
  775. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +16 -16
  776. data/src/core/lib/event_engine/posix_engine/event_poller.h +20 -25
  777. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +13 -25
  778. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +3 -2
  779. data/src/core/lib/event_engine/posix_engine/file_descriptor_collection.cc +124 -0
  780. data/src/core/lib/event_engine/posix_engine/file_descriptor_collection.h +243 -0
  781. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +33 -22
  782. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +7 -3
  783. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +6 -1
  784. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +7 -7
  785. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +4 -5
  786. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +7 -10
  787. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +4 -1
  788. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +179 -126
  789. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +46 -50
  790. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +514 -288
  791. data/src/core/lib/event_engine/posix_engine/posix_engine.h +79 -72
  792. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +56 -44
  793. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +9 -7
  794. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +40 -150
  795. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +7 -6
  796. data/src/core/lib/event_engine/posix_engine/posix_interface.h +211 -0
  797. data/src/core/lib/event_engine/posix_engine/posix_interface_posix.cc +1083 -0
  798. data/src/core/lib/event_engine/posix_engine/posix_interface_windows.cc +281 -0
  799. data/src/core/lib/event_engine/posix_engine/posix_write_event_sink.cc +154 -0
  800. data/src/core/lib/event_engine/posix_engine/posix_write_event_sink.h +174 -0
  801. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +4 -720
  802. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +12 -172
  803. data/src/core/lib/event_engine/posix_engine/timer.h +1 -1
  804. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +36 -25
  805. data/src/core/lib/event_engine/posix_engine/timer_manager.h +14 -12
  806. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +119 -153
  807. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +28 -96
  808. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +27 -26
  809. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +7 -3
  810. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +37 -63
  811. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +7 -3
  812. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +7 -6
  813. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +14 -8
  814. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +3 -1
  815. data/src/core/lib/event_engine/query_extensions.h +10 -21
  816. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +1 -1
  817. data/src/core/lib/event_engine/resolved_address.cc +3 -3
  818. data/src/core/lib/event_engine/shim.cc +14 -8
  819. data/src/core/lib/event_engine/shim.h +4 -0
  820. data/src/core/lib/event_engine/slice.cc +2 -2
  821. data/src/core/lib/event_engine/tcp_socket_utils.cc +25 -24
  822. data/src/core/lib/event_engine/thread_pool/thread_count.cc +1 -1
  823. data/src/core/lib/event_engine/thread_pool/thread_count.h +1 -1
  824. data/src/core/lib/event_engine/thread_pool/thread_pool.h +7 -3
  825. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +0 -17
  826. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +15 -13
  827. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +6 -5
  828. data/src/core/lib/event_engine/utils.cc +35 -1
  829. data/src/core/lib/event_engine/utils.h +4 -1
  830. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +38 -33
  831. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.h +6 -2
  832. data/src/core/lib/event_engine/windows/iocp.cc +11 -11
  833. data/src/core/lib/event_engine/windows/iocp.h +1 -1
  834. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.cc +5 -2
  835. data/src/core/lib/event_engine/windows/win_socket.cc +7 -7
  836. data/src/core/lib/event_engine/windows/win_socket.h +2 -2
  837. data/src/core/lib/event_engine/windows/windows_endpoint.cc +18 -18
  838. data/src/core/lib/event_engine/windows/windows_endpoint.h +5 -2
  839. data/src/core/lib/event_engine/windows/windows_engine.cc +20 -19
  840. data/src/core/lib/event_engine/windows/windows_engine.h +4 -6
  841. data/src/core/lib/event_engine/windows/windows_listener.cc +24 -12
  842. data/src/core/lib/event_engine/windows/windows_listener.h +2 -2
  843. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +2 -2
  844. data/src/core/lib/experiments/config.cc +4 -4
  845. data/src/core/lib/experiments/experiments.cc +591 -165
  846. data/src/core/lib/experiments/experiments.h +229 -89
  847. data/src/core/lib/iomgr/buffer_list.cc +1 -1
  848. data/src/core/lib/iomgr/call_combiner.cc +4 -4
  849. data/src/core/lib/iomgr/call_combiner.h +2 -2
  850. data/src/core/lib/iomgr/cfstream_handle.cc +1 -1
  851. data/src/core/lib/iomgr/closure.h +2 -2
  852. data/src/core/lib/iomgr/combiner.cc +5 -4
  853. data/src/core/lib/iomgr/endpoint.cc +4 -3
  854. data/src/core/lib/iomgr/endpoint.h +8 -5
  855. data/src/core/lib/iomgr/endpoint_cfstream.cc +10 -9
  856. data/src/core/lib/iomgr/endpoint_pair_posix.cc +6 -6
  857. data/src/core/lib/iomgr/endpoint_pair_windows.cc +16 -15
  858. data/src/core/lib/iomgr/error.cc +1 -1
  859. data/src/core/lib/iomgr/error.h +2 -2
  860. data/src/core/lib/iomgr/error_cfstream.cc +1 -1
  861. data/src/core/lib/iomgr/ev_apple.cc +1 -1
  862. data/src/core/lib/iomgr/ev_epoll1_linux.cc +26 -21
  863. data/src/core/lib/iomgr/ev_poll_posix.cc +25 -16
  864. data/src/core/lib/iomgr/ev_posix.cc +3 -3
  865. data/src/core/lib/iomgr/event_engine_shims/closure.cc +3 -3
  866. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -1
  867. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +21 -19
  868. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +1 -1
  869. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +2 -2
  870. data/src/core/lib/iomgr/exec_ctx.cc +3 -3
  871. data/src/core/lib/iomgr/exec_ctx.h +4 -10
  872. data/src/core/lib/iomgr/fork_posix.cc +1 -8
  873. data/src/core/lib/iomgr/internal_errqueue.cc +1 -1
  874. data/src/core/lib/iomgr/iocp_windows.cc +9 -9
  875. data/src/core/lib/iomgr/iomgr.cc +1 -4
  876. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +3 -0
  877. data/src/core/lib/iomgr/iomgr_windows.cc +3 -3
  878. data/src/core/lib/iomgr/lockfree_event.cc +3 -3
  879. data/src/core/lib/iomgr/polling_entity.cc +4 -4
  880. data/src/core/lib/iomgr/resolve_address.cc +1 -1
  881. data/src/core/lib/iomgr/resolve_address.h +2 -2
  882. data/src/core/lib/iomgr/resolve_address_posix.cc +37 -47
  883. data/src/core/lib/iomgr/resolve_address_posix.h +15 -0
  884. data/src/core/lib/iomgr/resolve_address_windows.cc +23 -46
  885. data/src/core/lib/iomgr/resolve_address_windows.h +15 -2
  886. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +1 -1
  887. data/src/core/lib/iomgr/socket_mutator.cc +1 -1
  888. data/src/core/lib/iomgr/socket_utils_common_posix.cc +4 -4
  889. data/src/core/lib/iomgr/socket_utils_posix.cc +1 -1
  890. data/src/core/lib/iomgr/socket_utils_posix.h +1 -1
  891. data/src/core/lib/iomgr/socket_windows.cc +6 -6
  892. data/src/core/lib/iomgr/tcp_client_cfstream.cc +1 -1
  893. data/src/core/lib/iomgr/tcp_client_posix.cc +22 -14
  894. data/src/core/lib/iomgr/tcp_client_windows.cc +4 -4
  895. data/src/core/lib/iomgr/tcp_posix.cc +75 -67
  896. data/src/core/lib/iomgr/tcp_server.cc +5 -0
  897. data/src/core/lib/iomgr/tcp_server.h +7 -0
  898. data/src/core/lib/iomgr/tcp_server_posix.cc +62 -31
  899. data/src/core/lib/iomgr/tcp_server_utils_posix.h +4 -1
  900. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +7 -7
  901. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +4 -4
  902. data/src/core/lib/iomgr/tcp_server_windows.cc +84 -33
  903. data/src/core/lib/iomgr/tcp_windows.cc +11 -10
  904. data/src/core/lib/iomgr/timer_generic.cc +5 -5
  905. data/src/core/lib/iomgr/timer_manager.cc +3 -3
  906. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -3
  907. data/src/core/lib/iomgr/unix_sockets_posix.h +1 -1
  908. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +2 -2
  909. data/src/core/lib/iomgr/vsock.cc +1 -1
  910. data/src/core/lib/iomgr/vsock.h +1 -1
  911. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +1 -1
  912. data/src/core/lib/promise/activity.cc +3 -3
  913. data/src/core/lib/promise/activity.h +14 -12
  914. data/src/core/lib/promise/all_ok.h +3 -3
  915. data/src/core/lib/promise/arena_promise.h +66 -9
  916. data/src/core/lib/promise/context.h +3 -3
  917. data/src/core/lib/promise/detail/join_state.h +10 -10
  918. data/src/core/lib/promise/detail/promise_factory.h +11 -1
  919. data/src/core/lib/promise/detail/promise_like.h +133 -2
  920. data/src/core/lib/promise/detail/promise_variant.h +50 -0
  921. data/src/core/lib/promise/detail/seq_state.h +896 -16
  922. data/src/core/lib/promise/detail/status.h +2 -2
  923. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +1 -1
  924. data/src/core/lib/promise/for_each.h +8 -8
  925. data/src/core/lib/promise/if.h +21 -1
  926. data/src/core/lib/promise/inter_activity_latch.h +147 -0
  927. data/src/core/lib/promise/inter_activity_mutex.h +547 -0
  928. data/src/core/lib/promise/interceptor_list.h +5 -5
  929. data/src/core/lib/promise/latch.h +9 -9
  930. data/src/core/lib/promise/loop.h +67 -5
  931. data/src/core/lib/promise/map.h +48 -7
  932. data/src/core/lib/promise/match_promise.h +103 -0
  933. data/src/core/lib/promise/mpsc.cc +426 -0
  934. data/src/core/lib/promise/mpsc.h +490 -0
  935. data/src/core/lib/promise/observable.h +6 -6
  936. data/src/core/lib/promise/party.cc +87 -25
  937. data/src/core/lib/promise/party.h +84 -15
  938. data/src/core/lib/promise/pipe.h +31 -17
  939. data/src/core/lib/promise/poll.h +16 -5
  940. data/src/core/lib/promise/promise.h +2 -2
  941. data/src/core/lib/promise/race.h +31 -0
  942. data/src/core/lib/promise/seq.h +5 -0
  943. data/src/core/lib/promise/sleep.cc +9 -4
  944. data/src/core/lib/promise/sleep.h +1 -1
  945. data/src/core/lib/promise/status_flag.h +15 -8
  946. data/src/core/lib/promise/try_join.h +5 -5
  947. data/src/core/lib/promise/try_seq.h +10 -5
  948. data/src/core/lib/promise/wait_set.cc +28 -0
  949. data/src/core/lib/promise/wait_set.h +86 -0
  950. data/src/core/lib/resource_quota/api.cc +1 -1
  951. data/src/core/lib/resource_quota/arena.cc +1 -1
  952. data/src/core/lib/resource_quota/arena.h +34 -2
  953. data/src/core/lib/resource_quota/connection_quota.cc +9 -7
  954. data/src/core/lib/resource_quota/connection_quota.h +1 -1
  955. data/src/core/lib/resource_quota/memory_quota.cc +145 -28
  956. data/src/core/lib/resource_quota/memory_quota.h +72 -27
  957. data/src/core/lib/resource_quota/periodic_update.cc +14 -0
  958. data/src/core/lib/resource_quota/periodic_update.h +9 -1
  959. data/src/core/lib/resource_quota/resource_quota.cc +23 -4
  960. data/src/core/lib/resource_quota/resource_quota.h +5 -1
  961. data/src/core/lib/resource_quota/stream_quota.cc +22 -0
  962. data/src/core/lib/resource_quota/stream_quota.h +31 -0
  963. data/src/core/lib/resource_quota/telemetry.h +55 -0
  964. data/src/core/lib/resource_quota/thread_quota.cc +2 -2
  965. data/src/core/lib/resource_quota/thread_quota.h +1 -1
  966. data/src/core/lib/resource_tracker/resource_tracker.cc +33 -0
  967. data/src/core/lib/resource_tracker/resource_tracker.h +46 -0
  968. data/src/core/lib/security/authorization/audit_logging.cc +7 -7
  969. data/src/core/lib/security/authorization/audit_logging.h +1 -1
  970. data/src/core/lib/security/authorization/authorization_policy_provider.h +1 -1
  971. data/src/core/lib/security/authorization/evaluate_args.cc +5 -5
  972. data/src/core/lib/security/authorization/evaluate_args.h +1 -1
  973. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +2 -2
  974. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +4 -5
  975. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +4 -1
  976. data/src/core/lib/security/authorization/matchers.cc +2 -2
  977. data/src/core/lib/security/authorization/stdout_logger.cc +3 -3
  978. data/src/core/lib/slice/percent_encoding.cc +1 -1
  979. data/src/core/lib/slice/slice.cc +1 -1
  980. data/src/core/lib/slice/slice.h +7 -2
  981. data/src/core/lib/slice/slice_buffer.cc +1 -1
  982. data/src/core/lib/slice/slice_buffer.h +6 -0
  983. data/src/core/lib/slice/slice_internal.h +1 -1
  984. data/src/core/lib/surface/byte_buffer_reader.cc +2 -2
  985. data/src/core/lib/surface/call.cc +65 -31
  986. data/src/core/lib/surface/call.h +19 -11
  987. data/src/core/lib/surface/call_log_batch.cc +2 -2
  988. data/src/core/lib/surface/call_utils.cc +7 -7
  989. data/src/core/lib/surface/call_utils.h +85 -20
  990. data/src/core/lib/surface/channel.cc +6 -5
  991. data/src/core/lib/surface/channel.h +13 -3
  992. data/src/core/lib/surface/channel_create.cc +145 -6
  993. data/src/core/lib/surface/channel_create.h +5 -1
  994. data/src/core/lib/surface/channel_init.cc +239 -65
  995. data/src/core/lib/surface/channel_init.h +90 -10
  996. data/src/core/lib/surface/completion_queue.cc +23 -24
  997. data/src/core/lib/surface/completion_queue_factory.cc +7 -7
  998. data/src/core/lib/surface/connection_context.h +45 -2
  999. data/src/core/lib/surface/filter_stack_call.cc +43 -40
  1000. data/src/core/lib/surface/filter_stack_call.h +6 -7
  1001. data/src/core/lib/surface/init.cc +12 -21
  1002. data/src/core/lib/surface/lame_client.cc +2 -2
  1003. data/src/core/lib/surface/lame_client.h +3 -3
  1004. data/src/core/lib/surface/legacy_channel.cc +13 -15
  1005. data/src/core/lib/surface/legacy_channel.h +4 -2
  1006. data/src/core/lib/surface/validate_metadata.cc +2 -2
  1007. data/src/core/lib/surface/validate_metadata.h +3 -3
  1008. data/src/core/lib/surface/version.cc +2 -2
  1009. data/src/core/lib/transport/bdp_estimator.cc +2 -2
  1010. data/src/core/lib/transport/bdp_estimator.h +5 -5
  1011. data/src/core/lib/transport/connectivity_state.cc +1 -1
  1012. data/src/core/lib/transport/connectivity_state.h +2 -2
  1013. data/src/core/lib/transport/error_utils.h +1 -1
  1014. data/src/core/lib/transport/promise_endpoint.cc +110 -0
  1015. data/src/core/lib/transport/promise_endpoint.h +307 -0
  1016. data/src/core/lib/transport/status_conversion.cc +7 -34
  1017. data/src/core/lib/transport/timeout_encoding.cc +4 -4
  1018. data/src/core/lib/transport/transport.cc +5 -5
  1019. data/src/core/lib/transport/transport.h +65 -4
  1020. data/src/core/lib/transport/transport_framing_endpoint_extension.h +1 -1
  1021. data/src/core/lib/transport/transport_op_string.cc +2 -2
  1022. data/src/core/load_balancing/address_filtering.cc +1 -1
  1023. data/src/core/load_balancing/address_filtering.h +2 -2
  1024. data/src/core/load_balancing/backend_metric_parser.cc +13 -19
  1025. data/src/core/load_balancing/backend_metric_parser.h +1 -1
  1026. data/src/core/load_balancing/child_policy_handler.cc +10 -12
  1027. data/src/core/load_balancing/child_policy_handler.h +2 -2
  1028. data/src/core/load_balancing/delegating_helper.h +4 -5
  1029. data/src/core/load_balancing/endpoint_list.cc +34 -7
  1030. data/src/core/load_balancing/endpoint_list.h +2 -2
  1031. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +10 -8
  1032. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +6 -2
  1033. data/src/core/load_balancing/grpclb/grpclb.cc +39 -50
  1034. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +2 -2
  1035. data/src/core/load_balancing/grpclb/load_balancer_api.cc +1 -1
  1036. data/src/core/load_balancing/grpclb/load_balancer_api.h +1 -1
  1037. data/src/core/load_balancing/health_check_client.cc +16 -18
  1038. data/src/core/load_balancing/health_check_client_internal.h +5 -5
  1039. data/src/core/load_balancing/lb_policy.h +12 -11
  1040. data/src/core/load_balancing/lb_policy_factory.h +2 -2
  1041. data/src/core/load_balancing/lb_policy_registry.cc +3 -3
  1042. data/src/core/load_balancing/lb_policy_registry.h +2 -2
  1043. data/src/core/load_balancing/oob_backend_metric.cc +14 -16
  1044. data/src/core/load_balancing/oob_backend_metric_internal.h +4 -4
  1045. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +13 -20
  1046. data/src/core/load_balancing/pick_first/pick_first.cc +80 -40
  1047. data/src/core/load_balancing/priority/priority.cc +29 -30
  1048. data/src/core/load_balancing/ring_hash/ring_hash.cc +11 -11
  1049. data/src/core/load_balancing/rls/rls.cc +29 -28
  1050. data/src/core/load_balancing/round_robin/round_robin.cc +18 -19
  1051. data/src/core/load_balancing/subchannel_interface.h +2 -2
  1052. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +3 -3
  1053. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +46 -45
  1054. data/src/core/load_balancing/weighted_target/weighted_target.cc +17 -23
  1055. data/src/core/load_balancing/xds/cds.cc +91 -38
  1056. data/src/core/load_balancing/xds/xds_cluster_impl.cc +29 -44
  1057. data/src/core/load_balancing/xds/xds_cluster_manager.cc +6 -6
  1058. data/src/core/load_balancing/xds/xds_override_host.cc +69 -48
  1059. data/src/core/load_balancing/xds/xds_override_host.h +1 -1
  1060. data/src/core/load_balancing/xds/xds_wrr_locality.cc +5 -5
  1061. data/src/core/net/socket_mutator.cc +19 -0
  1062. data/src/core/net/socket_mutator.h +25 -0
  1063. data/src/core/plugin_registry/grpc_plugin_registry.cc +8 -0
  1064. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +2 -0
  1065. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +8 -8
  1066. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +1 -1
  1067. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +7 -2
  1068. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -4
  1069. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +37 -36
  1070. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +24 -21
  1071. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +4 -3
  1072. data/src/core/resolver/dns/dns_resolver_plugin.cc +8 -5
  1073. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +10 -10
  1074. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +1 -1
  1075. data/src/core/resolver/dns/event_engine/service_config_helper.cc +2 -2
  1076. data/src/core/resolver/dns/native/dns_resolver.cc +7 -7
  1077. data/src/core/resolver/endpoint_addresses.cc +6 -6
  1078. data/src/core/resolver/endpoint_addresses.h +4 -1
  1079. data/src/core/resolver/fake/fake_resolver.cc +3 -3
  1080. data/src/core/resolver/fake/fake_resolver.h +3 -3
  1081. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +46 -59
  1082. data/src/core/resolver/polling_resolver.cc +8 -8
  1083. data/src/core/resolver/polling_resolver.h +1 -1
  1084. data/src/core/resolver/resolver.h +2 -2
  1085. data/src/core/resolver/resolver_factory.h +2 -2
  1086. data/src/core/resolver/resolver_registry.cc +5 -4
  1087. data/src/core/resolver/resolver_registry.h +1 -1
  1088. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +6 -5
  1089. data/src/core/resolver/xds/xds_config.cc +7 -4
  1090. data/src/core/resolver/xds/xds_config.h +12 -7
  1091. data/src/core/resolver/xds/xds_dependency_manager.cc +27 -12
  1092. data/src/core/resolver/xds/xds_dependency_manager.h +5 -4
  1093. data/src/core/resolver/xds/xds_resolver.cc +56 -32
  1094. data/src/core/resolver/xds/xds_resolver_attributes.h +1 -1
  1095. data/src/core/server/add_port.cc +87 -0
  1096. data/src/core/server/server.cc +175 -105
  1097. data/src/core/server/server.h +31 -13
  1098. data/src/core/server/server_call_tracer_filter.cc +1 -67
  1099. data/src/core/server/server_call_tracer_filter.h +68 -0
  1100. data/src/core/server/server_config_selector.h +2 -2
  1101. data/src/core/server/server_config_selector_filter.cc +6 -6
  1102. data/src/core/server/xds_channel_stack_modifier.cc +3 -2
  1103. data/src/core/server/xds_channel_stack_modifier.h +1 -1
  1104. data/src/core/server/xds_server_config_fetcher.cc +81 -42
  1105. data/src/core/service_config/service_config.h +2 -2
  1106. data/src/core/service_config/service_config_channel_arg_filter.cc +3 -60
  1107. data/src/core/service_config/service_config_channel_arg_filter.h +85 -0
  1108. data/src/core/service_config/service_config_impl.cc +3 -3
  1109. data/src/core/service_config/service_config_impl.h +5 -5
  1110. data/src/core/service_config/service_config_parser.h +1 -1
  1111. data/src/core/telemetry/call_tracer.cc +55 -59
  1112. data/src/core/telemetry/call_tracer.h +211 -29
  1113. data/src/core/telemetry/context_list_entry.cc +38 -0
  1114. data/src/core/{ext/transport/chttp2/transport → telemetry}/context_list_entry.h +45 -15
  1115. data/src/core/telemetry/default_tcp_tracer.cc +26 -0
  1116. data/src/core/telemetry/default_tcp_tracer.h +44 -0
  1117. data/src/core/telemetry/histogram.h +205 -0
  1118. data/src/core/telemetry/instrument.cc +999 -0
  1119. data/src/core/telemetry/instrument.h +1105 -0
  1120. data/src/core/telemetry/metrics.cc +15 -5
  1121. data/src/core/telemetry/metrics.h +44 -13
  1122. data/src/core/telemetry/stats.h +2 -7
  1123. data/src/core/telemetry/stats_data.cc +541 -492
  1124. data/src/core/telemetry/stats_data.h +470 -298
  1125. data/src/core/telemetry/tcp_tracer.cc +38 -0
  1126. data/src/core/telemetry/tcp_tracer.h +14 -16
  1127. data/src/core/transport/auth_context.cc +23 -4
  1128. data/src/core/transport/auth_context.h +6 -2
  1129. data/src/core/transport/auth_context_comparator_registry.h +69 -0
  1130. data/src/core/transport/endpoint_transport.h +90 -0
  1131. data/src/core/transport/endpoint_transport_client_channel_factory.cc +61 -0
  1132. data/src/core/transport/endpoint_transport_client_channel_factory.h +57 -0
  1133. data/src/core/tsi/alts/crypt/aes_gcm.cc +1 -1
  1134. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +2 -2
  1135. data/src/core/tsi/alts/frame_protector/frame_handler.cc +1 -1
  1136. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +115 -51
  1137. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +4 -1
  1138. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +3 -3
  1139. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +118 -54
  1140. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +8 -2
  1141. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +4 -4
  1142. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +1 -1
  1143. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +4 -4
  1144. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +11 -3
  1145. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol.h +10 -0
  1146. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +16 -8
  1147. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.h +3 -0
  1148. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +28 -7
  1149. data/src/core/tsi/fake_transport_security.cc +23 -5
  1150. data/src/core/tsi/local_transport_security.cc +1 -1
  1151. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +5 -5
  1152. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +1 -1
  1153. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +10 -10
  1154. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +4 -4
  1155. data/src/core/tsi/ssl_transport_security.cc +416 -125
  1156. data/src/core/tsi/ssl_transport_security.h +26 -12
  1157. data/src/core/tsi/ssl_transport_security_utils.cc +31 -10
  1158. data/src/core/tsi/ssl_transport_security_utils.h +6 -2
  1159. data/src/core/tsi/transport_security.h +3 -0
  1160. data/src/core/tsi/transport_security_grpc.cc +16 -0
  1161. data/src/core/tsi/transport_security_grpc.h +37 -3
  1162. data/src/core/tsi/transport_security_interface.h +30 -25
  1163. data/src/core/util/alloc.cc +1 -1
  1164. data/src/core/util/backoff.cc +5 -16
  1165. data/src/core/util/backoff.h +2 -2
  1166. data/src/core/util/chunked_vector.h +4 -4
  1167. data/src/core/util/crash.h +1 -1
  1168. data/src/core/util/down_cast.h +1 -1
  1169. data/src/core/util/dual_ref_counted.h +50 -2
  1170. data/src/core/util/event_log.cc +2 -2
  1171. data/src/core/util/event_log.h +3 -3
  1172. data/src/core/util/function_signature.h +80 -0
  1173. data/src/core/util/gcp_metadata_query.cc +10 -9
  1174. data/src/core/util/gcp_metadata_query.h +2 -2
  1175. data/src/core/util/glob.cc +2 -0
  1176. data/src/core/util/grpc_check.cc +24 -0
  1177. data/src/core/util/grpc_check.h +103 -0
  1178. data/src/core/util/grpc_if_nametoindex_posix.cc +1 -1
  1179. data/src/core/util/grpc_if_nametoindex_unsupported.cc +1 -1
  1180. data/src/core/util/http_client/format_request.cc +1 -1
  1181. data/src/core/util/http_client/httpcli.cc +17 -10
  1182. data/src/core/util/http_client/httpcli.h +8 -5
  1183. data/src/core/util/http_client/httpcli_security_connector.cc +9 -6
  1184. data/src/core/util/http_client/parser.cc +4 -4
  1185. data/src/core/util/json/json_channel_args.h +1 -1
  1186. data/src/core/util/json/json_object_loader.h +9 -9
  1187. data/src/core/util/json/json_reader.cc +2 -2
  1188. data/src/core/util/json/json_reader.h +1 -1
  1189. data/src/core/util/json/json_util.h +3 -3
  1190. data/src/core/util/json/json_writer.cc +1 -1
  1191. data/src/core/util/latent_see.cc +202 -123
  1192. data/src/core/util/latent_see.h +423 -204
  1193. data/src/core/util/linux/cpu.cc +1 -1
  1194. data/src/core/util/linux/env.cc +3 -1
  1195. data/src/core/util/load_file.cc +1 -1
  1196. data/src/core/util/load_file.h +1 -1
  1197. data/src/core/util/log.cc +7 -3
  1198. data/src/core/util/lru_cache.h +4 -4
  1199. data/src/core/util/matchers.h +1 -1
  1200. data/src/core/util/memory_usage.h +284 -0
  1201. data/src/core/util/mpscq.h +1 -1
  1202. data/src/core/util/notification.h +1 -1
  1203. data/src/core/util/per_cpu.cc +2 -0
  1204. data/src/core/util/per_cpu.h +7 -0
  1205. data/src/core/util/posix/cpu.cc +1 -1
  1206. data/src/core/util/posix/directory_reader.cc +3 -2
  1207. data/src/core/util/posix/stat.cc +2 -2
  1208. data/src/core/util/posix/sync.cc +24 -24
  1209. data/src/core/util/posix/thd.cc +2 -2
  1210. data/src/core/util/posix/tmpfile.cc +2 -2
  1211. data/src/core/util/postmortem_emit.cc +52 -0
  1212. data/src/core/util/postmortem_emit.h +30 -0
  1213. data/src/core/util/ref_counted.h +2 -2
  1214. data/src/core/util/ref_counted_ptr.h +32 -1
  1215. data/src/core/util/ref_counted_string.h +1 -1
  1216. data/src/core/util/shared_bit_gen.cc +21 -0
  1217. data/src/core/util/shared_bit_gen.h +64 -0
  1218. data/src/core/util/single_set_ptr.h +40 -4
  1219. data/src/core/util/status_helper.cc +8 -8
  1220. data/src/core/util/status_helper.h +1 -1
  1221. data/src/core/util/string.cc +2 -2
  1222. data/src/core/util/sync_abseil.cc +1 -1
  1223. data/src/core/util/table.h +1 -1
  1224. data/src/core/util/time.cc +1 -1
  1225. data/src/core/util/time_precise.cc +1 -1
  1226. data/src/core/util/trie_lookup.h +170 -0
  1227. data/src/core/util/unique_ptr_with_bitset.h +5 -5
  1228. data/src/core/util/unique_type_name.h +1 -1
  1229. data/src/core/util/upb_utils.h +48 -1
  1230. data/src/core/util/uri.cc +76 -17
  1231. data/src/core/util/uri.h +13 -8
  1232. data/src/core/util/useful.h +144 -2
  1233. data/src/core/util/validation_errors.cc +2 -2
  1234. data/src/core/util/validation_errors.h +2 -3
  1235. data/src/core/util/wait_for_single_owner.cc +31 -0
  1236. data/src/core/util/wait_for_single_owner.h +25 -1
  1237. data/src/core/util/windows/directory_reader.cc +2 -1
  1238. data/src/core/util/windows/stat.cc +2 -2
  1239. data/src/core/util/windows/thd.cc +3 -5
  1240. data/src/core/util/windows/time.cc +1 -1
  1241. data/src/core/util/work_serializer.cc +4 -4
  1242. data/src/core/util/work_serializer.h +2 -2
  1243. data/src/core/xds/grpc/certificate_provider_store.cc +2 -2
  1244. data/src/core/xds/grpc/certificate_provider_store.h +2 -2
  1245. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +35 -8
  1246. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +6 -1
  1247. data/src/core/xds/grpc/xds_audit_logger_registry.cc +3 -3
  1248. data/src/core/xds/grpc/xds_audit_logger_registry.h +1 -1
  1249. data/src/core/xds/grpc/xds_bootstrap_grpc.cc +9 -7
  1250. data/src/core/xds/grpc/xds_bootstrap_grpc.h +13 -3
  1251. data/src/core/xds/grpc/xds_certificate_provider.cc +9 -10
  1252. data/src/core/xds/grpc/xds_certificate_provider.h +2 -2
  1253. data/src/core/xds/grpc/xds_client_grpc.cc +43 -20
  1254. data/src/core/xds/grpc/xds_client_grpc.h +6 -3
  1255. data/src/core/xds/grpc/xds_cluster.cc +2 -2
  1256. data/src/core/xds/grpc/xds_cluster.h +1 -1
  1257. data/src/core/xds/grpc/xds_cluster_parser.cc +7 -7
  1258. data/src/core/xds/grpc/xds_cluster_parser.h +1 -1
  1259. data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +4 -4
  1260. data/src/core/xds/grpc/xds_cluster_specifier_plugin.h +1 -1
  1261. data/src/core/xds/grpc/xds_common_types.cc +1 -1
  1262. data/src/core/xds/grpc/xds_common_types.h +1 -1
  1263. data/src/core/xds/grpc/xds_common_types_parser.cc +143 -63
  1264. data/src/core/xds/grpc/xds_common_types_parser.h +12 -0
  1265. data/src/core/xds/grpc/xds_endpoint.h +2 -2
  1266. data/src/core/xds/grpc/xds_endpoint_parser.cc +7 -7
  1267. data/src/core/xds/grpc/xds_endpoint_parser.h +1 -1
  1268. data/src/core/xds/grpc/xds_health_status.cc +1 -1
  1269. data/src/core/xds/grpc/xds_health_status.h +1 -1
  1270. data/src/core/xds/grpc/xds_http_fault_filter.cc +4 -4
  1271. data/src/core/xds/grpc/xds_http_fault_filter.h +2 -2
  1272. data/src/core/xds/grpc/xds_http_filter.h +10 -3
  1273. data/src/core/xds/grpc/xds_http_filter_registry.cc +5 -6
  1274. data/src/core/xds/grpc/xds_http_filter_registry.h +2 -2
  1275. data/src/core/xds/grpc/xds_http_gcp_authn_filter.cc +25 -3
  1276. data/src/core/xds/grpc/xds_http_gcp_authn_filter.h +5 -2
  1277. data/src/core/xds/grpc/xds_http_rbac_filter.cc +14 -21
  1278. data/src/core/xds/grpc/xds_http_rbac_filter.h +2 -2
  1279. data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +3 -3
  1280. data/src/core/xds/grpc/xds_http_stateful_session_filter.h +2 -2
  1281. data/src/core/xds/grpc/xds_lb_policy_registry.cc +1 -1
  1282. data/src/core/xds/grpc/xds_lb_policy_registry.h +1 -1
  1283. data/src/core/xds/grpc/xds_listener.cc +2 -2
  1284. data/src/core/xds/grpc/xds_listener_parser.cc +9 -9
  1285. data/src/core/xds/grpc/xds_listener_parser.h +1 -1
  1286. data/src/core/xds/grpc/xds_matcher.cc +277 -0
  1287. data/src/core/xds/grpc/xds_matcher.h +432 -0
  1288. data/src/core/xds/grpc/xds_matcher_action.cc +47 -0
  1289. data/src/core/xds/grpc/xds_matcher_action.h +48 -0
  1290. data/src/core/xds/grpc/xds_matcher_context.cc +29 -0
  1291. data/src/core/xds/grpc/xds_matcher_context.h +46 -0
  1292. data/src/core/xds/grpc/xds_matcher_input.cc +79 -0
  1293. data/src/core/xds/grpc/xds_matcher_input.h +105 -0
  1294. data/src/core/xds/grpc/xds_matcher_parse.cc +356 -0
  1295. data/src/core/xds/grpc/xds_matcher_parse.h +39 -0
  1296. data/src/core/xds/grpc/xds_metadata.cc +4 -3
  1297. data/src/core/xds/grpc/xds_metadata.h +3 -3
  1298. data/src/core/xds/grpc/xds_metadata_parser.cc +42 -66
  1299. data/src/core/xds/grpc/xds_metadata_parser.h +0 -2
  1300. data/src/core/xds/grpc/xds_route_config.cc +3 -3
  1301. data/src/core/xds/grpc/xds_route_config_parser.cc +84 -129
  1302. data/src/core/xds/grpc/xds_route_config_parser.h +1 -1
  1303. data/src/core/xds/grpc/xds_routing.cc +6 -6
  1304. data/src/core/xds/grpc/xds_routing.h +2 -2
  1305. data/src/core/xds/grpc/xds_server_grpc.cc +65 -15
  1306. data/src/core/xds/grpc/xds_server_grpc.h +10 -2
  1307. data/src/core/xds/grpc/xds_server_grpc_interface.h +4 -0
  1308. data/src/core/xds/grpc/xds_transport_grpc.cc +29 -11
  1309. data/src/core/xds/grpc/xds_transport_grpc.h +2 -2
  1310. data/src/core/xds/xds_client/lrs_client.cc +9 -9
  1311. data/src/core/xds/xds_client/lrs_client.h +4 -4
  1312. data/src/core/xds/xds_client/xds_api.h +1 -1
  1313. data/src/core/xds/xds_client/xds_backend_metric_propagation.cc +1 -1
  1314. data/src/core/xds/xds_client/xds_backend_metric_propagation.h +1 -1
  1315. data/src/core/xds/xds_client/xds_bootstrap.h +2 -0
  1316. data/src/core/xds/xds_client/xds_client.cc +44 -23
  1317. data/src/core/xds/xds_client/xds_client.h +5 -5
  1318. data/src/core/xds/xds_client/xds_locality.h +2 -2
  1319. data/src/core/xds/xds_client/xds_resource_type.h +2 -2
  1320. data/src/core/xds/xds_client/xds_resource_type_impl.h +1 -1
  1321. data/src/core/xds/xds_client/xds_transport.h +2 -2
  1322. data/src/ruby/ext/grpc/extconf.rb +17 -13
  1323. data/src/ruby/ext/grpc/rb_call.c +1 -9
  1324. data/src/ruby/ext/grpc/rb_channel.c +70 -557
  1325. data/src/ruby/ext/grpc/rb_channel.h +0 -3
  1326. data/src/ruby/ext/grpc/rb_channel_args.c +0 -1
  1327. data/src/ruby/ext/grpc/rb_channel_credentials.c +0 -1
  1328. data/src/ruby/ext/grpc/rb_completion_queue.c +26 -14
  1329. data/src/ruby/ext/grpc/rb_completion_queue.h +1 -7
  1330. data/src/ruby/ext/grpc/rb_compression_options.c +0 -1
  1331. data/src/ruby/ext/grpc/rb_grpc.c +9 -5
  1332. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +3 -3
  1333. data/src/ruby/ext/grpc/rb_loader.c +0 -4
  1334. data/src/ruby/ext/grpc/rb_server.c +31 -50
  1335. data/src/ruby/ext/grpc/rb_server_credentials.c +0 -1
  1336. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +0 -1
  1337. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +0 -1
  1338. data/src/ruby/lib/grpc/generic/client_stub.rb +4 -4
  1339. data/src/ruby/lib/grpc/grpc.rb +7 -9
  1340. data/src/ruby/lib/grpc/version.rb +1 -1
  1341. data/src/ruby/spec/client_server_spec.rb +1 -1
  1342. data/src/ruby/spec/core_spec.rb +22 -0
  1343. data/src/ruby/spec/generic/active_call_spec.rb +1 -1
  1344. data/src/ruby/spec/generic/client_stub_spec.rb +2 -6
  1345. data/src/ruby/spec/generic/rpc_server_pool_spec.rb +1 -1
  1346. data/src/ruby/spec/generic/rpc_server_spec.rb +4 -5
  1347. data/src/ruby/spec/spec_helper.rb +1 -1
  1348. data/third_party/abseil-cpp/absl/algorithm/algorithm.h +2 -2
  1349. data/third_party/abseil-cpp/absl/algorithm/container.h +81 -67
  1350. data/third_party/abseil-cpp/absl/base/attributes.h +142 -23
  1351. data/third_party/abseil-cpp/absl/base/call_once.h +18 -16
  1352. data/third_party/abseil-cpp/absl/base/config.h +23 -132
  1353. data/third_party/abseil-cpp/absl/base/{internal/fast_type_id.h → fast_type_id.h} +11 -16
  1354. data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +0 -5
  1355. data/third_party/abseil-cpp/absl/base/internal/cycleclock_config.h +7 -7
  1356. data/third_party/abseil-cpp/absl/base/internal/endian.h +34 -38
  1357. data/third_party/abseil-cpp/absl/base/internal/iterator_traits.h +71 -0
  1358. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +6 -5
  1359. data/third_party/abseil-cpp/absl/base/internal/nullability_deprecated.h +106 -0
  1360. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +1 -1
  1361. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +0 -9
  1362. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +3 -13
  1363. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +14 -0
  1364. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +5 -1
  1365. data/third_party/abseil-cpp/absl/base/internal/tracing.cc +39 -0
  1366. data/third_party/abseil-cpp/absl/base/internal/tracing.h +81 -0
  1367. data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +6 -6
  1368. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -10
  1369. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +17 -0
  1370. data/third_party/abseil-cpp/absl/base/macros.h +35 -4
  1371. data/third_party/abseil-cpp/absl/base/no_destructor.h +11 -32
  1372. data/third_party/abseil-cpp/absl/base/nullability.h +124 -56
  1373. data/third_party/abseil-cpp/absl/base/optimization.h +8 -12
  1374. data/third_party/abseil-cpp/absl/base/options.h +7 -81
  1375. data/third_party/abseil-cpp/absl/base/policy_checks.h +9 -7
  1376. data/third_party/abseil-cpp/absl/cleanup/cleanup.h +1 -3
  1377. data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +3 -4
  1378. data/third_party/abseil-cpp/absl/container/btree_map.h +891 -0
  1379. data/third_party/abseil-cpp/absl/container/btree_set.h +826 -0
  1380. data/third_party/abseil-cpp/absl/container/fixed_array.h +9 -15
  1381. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +22 -3
  1382. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +23 -4
  1383. data/third_party/abseil-cpp/absl/container/inlined_vector.h +10 -6
  1384. data/third_party/abseil-cpp/absl/container/internal/btree.h +3149 -0
  1385. data/third_party/abseil-cpp/absl/container/internal/btree_container.h +867 -0
  1386. data/third_party/abseil-cpp/absl/container/internal/common.h +43 -0
  1387. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +10 -2
  1388. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +10 -10
  1389. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +1 -8
  1390. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +0 -4
  1391. data/third_party/abseil-cpp/absl/container/internal/hashtable_control_bytes.h +527 -0
  1392. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +20 -4
  1393. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +31 -12
  1394. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +6 -9
  1395. data/third_party/abseil-cpp/absl/container/internal/layout.h +27 -43
  1396. data/third_party/abseil-cpp/absl/container/internal/node_slot_policy.h +95 -0
  1397. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +199 -68
  1398. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +1462 -263
  1399. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1170 -1547
  1400. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl.h +80 -0
  1401. data/third_party/abseil-cpp/absl/container/node_hash_map.h +687 -0
  1402. data/third_party/abseil-cpp/absl/crc/crc32c.cc +0 -4
  1403. data/third_party/abseil-cpp/absl/crc/crc32c.h +7 -5
  1404. data/third_party/abseil-cpp/absl/crc/internal/cpu_detect.cc +56 -0
  1405. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +0 -22
  1406. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +45 -74
  1407. data/third_party/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +21 -7
  1408. data/third_party/abseil-cpp/absl/debugging/internal/addresses.h +57 -0
  1409. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +1 -1
  1410. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +5 -5
  1411. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +12 -37
  1412. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.cc +16 -16
  1413. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +1 -1
  1414. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +40 -21
  1415. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +16 -7
  1416. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +7 -0
  1417. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +14 -5
  1418. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +10 -4
  1419. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +27 -16
  1420. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +20 -8
  1421. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +4 -3
  1422. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +15 -28
  1423. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +19 -9
  1424. data/third_party/abseil-cpp/absl/debugging/leak_check.cc +73 -0
  1425. data/third_party/abseil-cpp/absl/debugging/leak_check.h +150 -0
  1426. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +144 -27
  1427. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +73 -5
  1428. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +3 -2
  1429. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +67 -18
  1430. data/third_party/abseil-cpp/absl/debugging/symbolize_emscripten.inc +3 -2
  1431. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +25 -6
  1432. data/third_party/abseil-cpp/absl/flags/commandlineflag.cc +1 -0
  1433. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +9 -2
  1434. data/third_party/abseil-cpp/absl/flags/flag.h +18 -15
  1435. data/third_party/abseil-cpp/absl/flags/internal/commandlineflag.h +2 -2
  1436. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +14 -5
  1437. data/third_party/abseil-cpp/absl/flags/internal/flag.h +23 -11
  1438. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +4 -0
  1439. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.h +3 -0
  1440. data/third_party/abseil-cpp/absl/flags/internal/program_name.cc +13 -12
  1441. data/third_party/abseil-cpp/absl/flags/internal/registry.h +4 -3
  1442. data/third_party/abseil-cpp/absl/flags/reflection.cc +2 -3
  1443. data/third_party/abseil-cpp/absl/flags/usage_config.cc +9 -4
  1444. data/third_party/abseil-cpp/absl/functional/any_invocable.h +8 -10
  1445. data/third_party/abseil-cpp/absl/functional/function_ref.h +2 -9
  1446. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +110 -226
  1447. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +10 -12
  1448. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +2 -5
  1449. data/third_party/abseil-cpp/absl/hash/hash.h +44 -2
  1450. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +14 -18
  1451. data/third_party/abseil-cpp/absl/hash/internal/hash.h +257 -127
  1452. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +27 -72
  1453. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +2 -6
  1454. data/third_party/abseil-cpp/absl/hash/internal/weakly_mixed_integer.h +38 -0
  1455. data/third_party/abseil-cpp/absl/log/absl_vlog_is_on.h +2 -0
  1456. data/third_party/abseil-cpp/absl/log/check.h +2 -1
  1457. data/third_party/abseil-cpp/absl/log/globals.h +4 -5
  1458. data/third_party/abseil-cpp/absl/log/internal/append_truncated.h +28 -0
  1459. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +43 -38
  1460. data/third_party/abseil-cpp/absl/log/internal/check_op.h +124 -99
  1461. data/third_party/abseil-cpp/absl/log/internal/conditions.cc +5 -3
  1462. data/third_party/abseil-cpp/absl/log/internal/conditions.h +7 -2
  1463. data/third_party/abseil-cpp/absl/log/internal/log_message.cc +158 -64
  1464. data/third_party/abseil-cpp/absl/log/internal/log_message.h +140 -83
  1465. data/third_party/abseil-cpp/absl/log/internal/nullstream.h +1 -0
  1466. data/third_party/abseil-cpp/absl/log/internal/proto.cc +3 -5
  1467. data/third_party/abseil-cpp/absl/log/internal/proto.h +28 -18
  1468. data/third_party/abseil-cpp/absl/log/internal/strip.h +4 -12
  1469. data/third_party/abseil-cpp/absl/log/internal/structured_proto.cc +115 -0
  1470. data/third_party/abseil-cpp/absl/log/internal/structured_proto.h +107 -0
  1471. data/third_party/abseil-cpp/absl/log/internal/vlog_config.cc +8 -1
  1472. data/third_party/abseil-cpp/absl/log/internal/vlog_config.h +8 -6
  1473. data/third_party/abseil-cpp/absl/log/internal/voidify.h +10 -4
  1474. data/third_party/abseil-cpp/absl/log/log.h +48 -35
  1475. data/third_party/abseil-cpp/absl/log/log_sink_registry.h +5 -2
  1476. data/third_party/abseil-cpp/absl/log/vlog_is_on.h +2 -0
  1477. data/third_party/abseil-cpp/absl/meta/type_traits.h +62 -181
  1478. data/third_party/abseil-cpp/absl/numeric/bits.h +68 -2
  1479. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -52
  1480. data/third_party/abseil-cpp/absl/numeric/int128.h +15 -3
  1481. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +6 -4
  1482. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +6 -3
  1483. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +7 -3
  1484. data/third_party/abseil-cpp/absl/profiling/internal/exponential_biased.cc +1 -1
  1485. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +3 -1
  1486. data/third_party/abseil-cpp/absl/random/beta_distribution.h +3 -1
  1487. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +12 -12
  1488. data/third_party/abseil-cpp/absl/random/discrete_distribution.cc +10 -0
  1489. data/third_party/abseil-cpp/absl/random/discrete_distribution.h +4 -2
  1490. data/third_party/abseil-cpp/absl/random/distributions.h +6 -8
  1491. data/third_party/abseil-cpp/absl/random/exponential_distribution.h +1 -0
  1492. data/third_party/abseil-cpp/absl/random/gaussian_distribution.h +3 -2
  1493. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +8 -7
  1494. data/third_party/abseil-cpp/absl/random/internal/{pool_urbg.cc → entropy_pool.cc} +22 -90
  1495. data/third_party/abseil-cpp/absl/random/internal/entropy_pool.h +35 -0
  1496. data/third_party/abseil-cpp/absl/random/internal/iostream_state_saver.h +5 -2
  1497. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +5 -6
  1498. data/third_party/abseil-cpp/absl/random/internal/platform.h +12 -12
  1499. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +57 -6
  1500. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +2 -1
  1501. data/third_party/abseil-cpp/absl/random/internal/seed_material.cc +20 -12
  1502. data/third_party/abseil-cpp/absl/random/internal/seed_material.h +5 -5
  1503. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +2 -2
  1504. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +0 -1
  1505. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +1 -4
  1506. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +4 -3
  1507. data/third_party/abseil-cpp/absl/random/random.h +88 -53
  1508. data/third_party/abseil-cpp/absl/random/seed_gen_exception.cc +2 -3
  1509. data/third_party/abseil-cpp/absl/random/seed_sequences.cc +6 -2
  1510. data/third_party/abseil-cpp/absl/random/seed_sequences.h +1 -2
  1511. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +2 -1
  1512. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +2 -0
  1513. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +5 -4
  1514. data/third_party/abseil-cpp/absl/status/internal/status_internal.cc +10 -7
  1515. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +3 -4
  1516. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +4 -3
  1517. data/third_party/abseil-cpp/absl/status/status.cc +4 -8
  1518. data/third_party/abseil-cpp/absl/status/status.h +8 -8
  1519. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +2 -2
  1520. data/third_party/abseil-cpp/absl/status/statusor.cc +2 -2
  1521. data/third_party/abseil-cpp/absl/status/statusor.h +6 -6
  1522. data/third_party/abseil-cpp/absl/strings/ascii.cc +44 -29
  1523. data/third_party/abseil-cpp/absl/strings/ascii.h +62 -22
  1524. data/third_party/abseil-cpp/absl/strings/charconv.cc +25 -29
  1525. data/third_party/abseil-cpp/absl/strings/charconv.h +5 -5
  1526. data/third_party/abseil-cpp/absl/strings/charset.h +3 -4
  1527. data/third_party/abseil-cpp/absl/strings/cord.cc +54 -58
  1528. data/third_party/abseil-cpp/absl/strings/cord.h +99 -102
  1529. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +11 -11
  1530. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +3 -3
  1531. data/third_party/abseil-cpp/absl/strings/escaping.cc +186 -197
  1532. data/third_party/abseil-cpp/absl/strings/escaping.h +9 -10
  1533. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +1 -1
  1534. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +1 -1
  1535. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +53 -22
  1536. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +0 -4
  1537. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +0 -4
  1538. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +7 -63
  1539. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +1 -11
  1540. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +0 -22
  1541. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +3 -2
  1542. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.cc +5 -3
  1543. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +4 -2
  1544. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +3 -3
  1545. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +35 -0
  1546. data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +0 -5
  1547. data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +96 -1
  1548. data/third_party/abseil-cpp/absl/strings/internal/utf8.h +15 -1
  1549. data/third_party/abseil-cpp/absl/strings/match.h +21 -11
  1550. data/third_party/abseil-cpp/absl/strings/numbers.cc +55 -33
  1551. data/third_party/abseil-cpp/absl/strings/numbers.h +87 -58
  1552. data/third_party/abseil-cpp/absl/strings/str_cat.cc +6 -7
  1553. data/third_party/abseil-cpp/absl/strings/str_cat.h +41 -30
  1554. data/third_party/abseil-cpp/absl/strings/str_format.h +18 -18
  1555. data/third_party/abseil-cpp/absl/strings/str_replace.cc +3 -3
  1556. data/third_party/abseil-cpp/absl/strings/str_replace.h +6 -6
  1557. data/third_party/abseil-cpp/absl/strings/str_split.h +18 -1
  1558. data/third_party/abseil-cpp/absl/strings/string_view.cc +4 -9
  1559. data/third_party/abseil-cpp/absl/strings/string_view.h +46 -50
  1560. data/third_party/abseil-cpp/absl/strings/strip.h +11 -8
  1561. data/third_party/abseil-cpp/absl/strings/substitute.cc +5 -4
  1562. data/third_party/abseil-cpp/absl/strings/substitute.h +66 -64
  1563. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +16 -10
  1564. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +6 -0
  1565. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +5 -1
  1566. data/third_party/abseil-cpp/absl/synchronization/internal/futex_waiter.cc +0 -4
  1567. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.cc +0 -5
  1568. data/third_party/abseil-cpp/absl/synchronization/internal/pthread_waiter.cc +0 -4
  1569. data/third_party/abseil-cpp/absl/synchronization/internal/sem_waiter.cc +0 -4
  1570. data/third_party/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.cc +0 -4
  1571. data/third_party/abseil-cpp/absl/synchronization/internal/waiter_base.cc +0 -4
  1572. data/third_party/abseil-cpp/absl/synchronization/internal/win32_waiter.cc +0 -4
  1573. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +39 -13
  1574. data/third_party/abseil-cpp/absl/synchronization/mutex.h +97 -69
  1575. data/third_party/abseil-cpp/absl/synchronization/notification.cc +10 -2
  1576. data/third_party/abseil-cpp/absl/synchronization/notification.h +12 -2
  1577. data/third_party/abseil-cpp/absl/time/civil_time.cc +1 -0
  1578. data/third_party/abseil-cpp/absl/time/duration.cc +18 -58
  1579. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +1 -1
  1580. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +1 -1
  1581. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +1 -1
  1582. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +3 -3
  1583. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +2 -2
  1584. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +2 -2
  1585. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +3 -3
  1586. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +2 -2
  1587. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +1 -1
  1588. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +1 -1
  1589. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +92 -112
  1590. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +1 -1
  1591. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +6 -4
  1592. data/third_party/abseil-cpp/absl/time/time.h +89 -23
  1593. data/third_party/abseil-cpp/absl/types/internal/span.h +3 -2
  1594. data/third_party/abseil-cpp/absl/types/optional.h +7 -745
  1595. data/third_party/abseil-cpp/absl/types/span.h +98 -54
  1596. data/third_party/abseil-cpp/absl/types/variant.h +5 -784
  1597. data/third_party/abseil-cpp/absl/utility/utility.h +10 -185
  1598. data/third_party/boringssl-with-bazel/src/crypto/aes/aes.cc +41 -0
  1599. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.cc +16 -0
  1600. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.cc +15 -0
  1601. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +19 -3
  1602. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.cc +79 -48
  1603. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.cc +11 -19
  1604. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.cc +3 -7
  1605. data/third_party/boringssl-with-bazel/src/crypto/bcm_support.h +0 -35
  1606. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.cc +0 -2
  1607. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +3 -5
  1608. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.cc +0 -3
  1609. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.cc +0 -2
  1610. data/third_party/boringssl-with-bazel/src/crypto/bn/convert.cc +31 -47
  1611. data/third_party/boringssl-with-bazel/src/crypto/bn/div.cc +100 -0
  1612. data/third_party/boringssl-with-bazel/src/crypto/bn/exponentiation.cc +166 -0
  1613. data/third_party/boringssl-with-bazel/src/crypto/bn/sqrt.cc +93 -0
  1614. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.cc +14 -8
  1615. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.cc +1 -1
  1616. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +3 -3
  1617. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +4 -4
  1618. data/third_party/boringssl-with-bazel/src/crypto/cipher/derive_key.cc +13 -15
  1619. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aeseax.cc +289 -0
  1620. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aesgcmsiv.cc +179 -102
  1621. data/third_party/boringssl-with-bazel/src/crypto/cipher/internal.h +3 -3
  1622. data/third_party/boringssl-with-bazel/src/crypto/cms/cms.cc +172 -0
  1623. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.cc +28 -5
  1624. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.h +11 -9
  1625. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.cc +0 -6
  1626. data/third_party/boringssl-with-bazel/src/crypto/crypto.cc +1 -1
  1627. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +3 -3
  1628. data/third_party/boringssl-with-bazel/src/crypto/des/internal.h +3 -3
  1629. data/third_party/boringssl-with-bazel/src/crypto/dh/dh_asn1.cc +13 -14
  1630. data/third_party/boringssl-with-bazel/src/crypto/dh/params.cc +27 -61
  1631. data/third_party/boringssl-with-bazel/src/crypto/digest/digest_extra.cc +16 -8
  1632. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.cc +112 -122
  1633. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.cc +23 -35
  1634. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +3 -3
  1635. data/third_party/boringssl-with-bazel/src/crypto/ec/ec_asn1.cc +47 -63
  1636. data/third_party/boringssl-with-bazel/src/crypto/ec/hash_to_curve.cc +60 -68
  1637. data/third_party/boringssl-with-bazel/src/crypto/ec/internal.h +3 -3
  1638. data/third_party/boringssl-with-bazel/src/crypto/ecdsa/ecdsa_asn1.cc +11 -17
  1639. data/third_party/boringssl-with-bazel/src/crypto/err/err.cc +0 -2
  1640. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.cc +10 -11
  1641. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.cc +10 -11
  1642. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +3 -3
  1643. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.cc +6 -6
  1644. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.cc +6 -6
  1645. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.cc +6 -6
  1646. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.cc +6 -6
  1647. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.cc +6 -6
  1648. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.cc +23 -42
  1649. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.cc.inc +29 -18
  1650. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/gcm.cc.inc +10 -10
  1651. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +16 -45
  1652. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.cc.inc +5 -4
  1653. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.cc.inc +15 -6
  1654. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.cc +3 -3
  1655. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm_interface.h +101 -5
  1656. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.cc.inc +96 -187
  1657. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.cc.inc +24 -512
  1658. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.cc.inc +58 -80
  1659. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.cc.inc +29 -45
  1660. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +27 -25
  1661. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.cc.inc +7 -16
  1662. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.cc.inc +27 -48
  1663. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.cc.inc +34 -34
  1664. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.cc.inc +102 -154
  1665. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +3 -3
  1666. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.cc.inc +3 -8
  1667. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.cc.inc +1 -78
  1668. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.cc.inc +10 -17
  1669. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +3 -3
  1670. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +15 -8
  1671. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.cc.inc +40 -53
  1672. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.cc.inc +57 -76
  1673. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.cc.inc +4 -10
  1674. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/internal.h +3 -3
  1675. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +3 -3
  1676. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.cc.inc +37 -52
  1677. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.cc.inc +13 -20
  1678. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +3 -3
  1679. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.cc.inc +28 -39
  1680. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.h +3 -3
  1681. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.cc.inc +6 -11
  1682. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/keccak/internal.h +3 -3
  1683. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mldsa/fips_known_values.inc +1345 -0
  1684. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mldsa/mldsa.cc.inc +335 -28
  1685. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mlkem/fips_known_values.inc +411 -0
  1686. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mlkem/mlkem.cc.inc +265 -33
  1687. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +3 -3
  1688. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.cc.inc +1 -1
  1689. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +3 -3
  1690. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.cc.inc +19 -26
  1691. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.cc.inc +7 -7
  1692. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.cc.inc +121 -138
  1693. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.cc.inc +96 -83
  1694. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +3 -3
  1695. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +8 -20
  1696. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/fips_known_values.inc +674 -0
  1697. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/slhdsa.cc.inc +235 -60
  1698. data/third_party/boringssl-with-bazel/src/crypto/fuzzer_mode.cc +30 -0
  1699. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +3 -3
  1700. data/third_party/boringssl-with-bazel/src/crypto/internal.h +39 -30
  1701. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +3 -3
  1702. data/third_party/boringssl-with-bazel/src/crypto/md5/internal.h +3 -3
  1703. data/third_party/boringssl-with-bazel/src/crypto/mem.cc +0 -2
  1704. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.cc +2 -8
  1705. data/third_party/boringssl-with-bazel/src/crypto/pem/internal.h +3 -3
  1706. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.cc +8 -13
  1707. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +22 -8
  1708. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.cc +19 -17
  1709. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.cc +134 -136
  1710. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +14 -8
  1711. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.cc +25 -21
  1712. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.cc +36 -52
  1713. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.cc +97 -79
  1714. data/third_party/boringssl-with-bazel/src/crypto/poly1305/internal.h +3 -3
  1715. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +3 -3
  1716. data/third_party/boringssl-with-bazel/src/crypto/rand/deterministic.cc +1 -1
  1717. data/third_party/boringssl-with-bazel/src/crypto/rand/fork_detect.cc +2 -2
  1718. data/third_party/boringssl-with-bazel/src/crypto/rand/getentropy.cc +1 -1
  1719. data/third_party/boringssl-with-bazel/src/crypto/rand/{sysrand_internal.h → internal.h} +22 -4
  1720. data/third_party/boringssl-with-bazel/src/crypto/rand/ios.cc +1 -1
  1721. data/third_party/boringssl-with-bazel/src/crypto/rand/trusty.cc +1 -1
  1722. data/third_party/boringssl-with-bazel/src/crypto/rand/urandom.cc +1 -1
  1723. data/third_party/boringssl-with-bazel/src/crypto/rand/windows.cc +1 -5
  1724. data/third_party/boringssl-with-bazel/src/crypto/rsa/internal.h +3 -3
  1725. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_crypt.cc +14 -22
  1726. data/third_party/boringssl-with-bazel/src/crypto/spake2plus/internal.h +3 -3
  1727. data/third_party/boringssl-with-bazel/src/crypto/thread_win.cc +0 -2
  1728. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +3 -3
  1729. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.cc +3 -5
  1730. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.cc +8 -12
  1731. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +15 -3
  1732. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_conf.cc +16 -24
  1733. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.cc +18 -21
  1734. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.cc +10 -3
  1735. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.cc +9 -0
  1736. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.cc +10 -1
  1737. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.cc +64 -85
  1738. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.cc +16 -32
  1739. data/third_party/boringssl-with-bazel/src/gen/crypto/err_data.cc +576 -567
  1740. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +16 -8
  1741. data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +1 -1
  1742. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +6 -54
  1743. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +1 -1
  1744. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +8 -4
  1745. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +1 -1
  1746. data/third_party/boringssl-with-bazel/src/include/openssl/bcm_public.h +1 -1
  1747. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +1 -1
  1748. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +1 -1
  1749. data/third_party/boringssl-with-bazel/src/include/openssl/blowfish.h +1 -1
  1750. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +1 -1
  1751. data/third_party/boringssl-with-bazel/src/include/openssl/buf.h +1 -1
  1752. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +7 -1
  1753. data/third_party/boringssl-with-bazel/src/include/openssl/cast.h +1 -1
  1754. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +1 -1
  1755. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +1 -1
  1756. data/third_party/boringssl-with-bazel/src/include/openssl/cmac.h +1 -1
  1757. data/third_party/boringssl-with-bazel/src/include/openssl/cms.h +146 -0
  1758. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +1 -1
  1759. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +23 -3
  1760. data/third_party/boringssl-with-bazel/src/include/openssl/ctrdrbg.h +1 -1
  1761. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +1 -1
  1762. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +1 -1
  1763. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +1 -1
  1764. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +19 -7
  1765. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +1 -1
  1766. data/third_party/boringssl-with-bazel/src/include/openssl/e_os2.h +1 -1
  1767. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +1 -1
  1768. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +1 -1
  1769. data/third_party/boringssl-with-bazel/src/include/openssl/ecdh.h +1 -1
  1770. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +1 -1
  1771. data/third_party/boringssl-with-bazel/src/include/openssl/engine.h +1 -1
  1772. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +2 -1
  1773. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +1 -1
  1774. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +1 -1
  1775. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/kyber.h +1 -1
  1776. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +1 -1
  1777. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +1 -1
  1778. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +4 -4
  1779. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +1 -1
  1780. data/third_party/boringssl-with-bazel/src/include/openssl/kdf.h +1 -1
  1781. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +1 -1
  1782. data/third_party/boringssl-with-bazel/src/include/openssl/md4.h +1 -1
  1783. data/third_party/boringssl-with-bazel/src/include/openssl/md5.h +1 -1
  1784. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +1 -1
  1785. data/third_party/boringssl-with-bazel/src/include/openssl/mldsa.h +1 -1
  1786. data/third_party/boringssl-with-bazel/src/include/openssl/mlkem.h +1 -1
  1787. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +1 -1
  1788. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +1 -1
  1789. data/third_party/boringssl-with-bazel/src/include/openssl/obj_mac.h +1 -1
  1790. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +10 -4
  1791. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +1 -1
  1792. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +19 -6
  1793. data/third_party/boringssl-with-bazel/src/include/openssl/poly1305.h +1 -1
  1794. data/third_party/boringssl-with-bazel/src/include/openssl/pool.h +1 -1
  1795. data/third_party/boringssl-with-bazel/src/include/openssl/posix_time.h +1 -1
  1796. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +2 -2
  1797. data/third_party/boringssl-with-bazel/src/include/openssl/rc4.h +1 -1
  1798. data/third_party/boringssl-with-bazel/src/include/openssl/ripemd.h +1 -1
  1799. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +2 -2
  1800. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +1 -1
  1801. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +1 -1
  1802. data/third_party/boringssl-with-bazel/src/include/openssl/siphash.h +1 -1
  1803. data/third_party/boringssl-with-bazel/src/include/openssl/slhdsa.h +1 -1
  1804. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +1 -1
  1805. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +291 -40
  1806. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +1 -1
  1807. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +0 -5
  1808. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +1 -1
  1809. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +9 -1
  1810. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +1 -1
  1811. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +1 -1
  1812. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +7 -4
  1813. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +2 -0
  1814. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +32 -26
  1815. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +49 -49
  1816. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +253 -50
  1817. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +12 -12
  1818. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +7 -5
  1819. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +2 -1
  1820. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +24 -32
  1821. data/third_party/boringssl-with-bazel/src/ssl/internal.h +93 -4
  1822. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +6 -12
  1823. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +18 -4
  1824. data/third_party/boringssl-with-bazel/src/ssl/ssl_credential.cc +83 -7
  1825. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +1 -1
  1826. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +173 -19
  1827. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +5 -18
  1828. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +28 -15
  1829. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +1 -1
  1830. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +31 -7
  1831. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +13 -1
  1832. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +7 -11
  1833. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +13 -11
  1834. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +2 -5
  1835. data/third_party/cares/cares/include/ares.h +925 -460
  1836. data/third_party/cares/cares/include/ares_dns.h +86 -71
  1837. data/third_party/cares/cares/include/ares_dns_record.h +1118 -0
  1838. data/third_party/cares/cares/include/ares_nameser.h +215 -189
  1839. data/third_party/cares/cares/include/ares_version.h +37 -14
  1840. data/third_party/cares/cares/src/lib/ares_addrinfo2hostent.c +305 -0
  1841. data/third_party/cares/cares/src/lib/ares_addrinfo_localhost.c +245 -0
  1842. data/third_party/cares/cares/src/lib/ares_android.c +216 -164
  1843. data/third_party/cares/cares/src/lib/ares_android.h +25 -14
  1844. data/third_party/cares/cares/src/lib/ares_cancel.c +68 -44
  1845. data/third_party/cares/cares/src/lib/ares_close_sockets.c +137 -0
  1846. data/third_party/cares/cares/src/lib/ares_conn.c +511 -0
  1847. data/third_party/cares/cares/src/lib/ares_conn.h +196 -0
  1848. data/third_party/cares/cares/src/lib/ares_cookie.c +461 -0
  1849. data/third_party/cares/cares/src/lib/ares_data.c +93 -181
  1850. data/third_party/cares/cares/src/lib/ares_data.h +50 -39
  1851. data/third_party/cares/cares/src/lib/ares_destroy.c +127 -89
  1852. data/third_party/cares/cares/src/lib/ares_free_hostent.c +35 -24
  1853. data/third_party/cares/cares/src/lib/ares_free_string.c +24 -16
  1854. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +45 -38
  1855. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +549 -663
  1856. data/third_party/cares/cares/src/lib/ares_getenv.c +25 -15
  1857. data/third_party/cares/cares/src/lib/ares_getenv.h +26 -18
  1858. data/third_party/cares/cares/src/lib/ares_gethostbyaddr.c +163 -221
  1859. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +222 -223
  1860. data/third_party/cares/cares/src/lib/ares_getnameinfo.c +328 -338
  1861. data/third_party/cares/cares/src/lib/ares_hosts_file.c +952 -0
  1862. data/third_party/cares/cares/src/lib/ares_inet_net_pton.h +25 -19
  1863. data/third_party/cares/cares/src/lib/ares_init.c +425 -2091
  1864. data/third_party/cares/cares/src/lib/ares_ipv6.h +63 -33
  1865. data/third_party/cares/cares/src/lib/ares_library_init.c +110 -54
  1866. data/third_party/cares/cares/src/lib/ares_metrics.c +261 -0
  1867. data/third_party/cares/cares/src/lib/ares_options.c +418 -332
  1868. data/third_party/cares/cares/src/lib/ares_parse_into_addrinfo.c +179 -0
  1869. data/third_party/cares/cares/src/lib/ares_private.h +558 -356
  1870. data/third_party/cares/cares/src/lib/ares_process.c +1224 -1369
  1871. data/third_party/cares/cares/src/lib/ares_qcache.c +430 -0
  1872. data/third_party/cares/cares/src/lib/ares_query.c +126 -121
  1873. data/third_party/cares/cares/src/lib/ares_search.c +564 -262
  1874. data/third_party/cares/cares/src/lib/ares_send.c +264 -93
  1875. data/third_party/cares/cares/src/lib/ares_set_socket_functions.c +588 -0
  1876. data/third_party/cares/cares/src/lib/ares_setup.h +115 -111
  1877. data/third_party/cares/cares/src/lib/ares_socket.c +425 -0
  1878. data/third_party/cares/cares/src/lib/ares_socket.h +163 -0
  1879. data/third_party/cares/cares/src/lib/ares_sortaddrinfo.c +447 -0
  1880. data/third_party/cares/cares/src/lib/ares_strerror.c +83 -48
  1881. data/third_party/cares/cares/src/lib/ares_sysconfig.c +639 -0
  1882. data/third_party/cares/cares/src/lib/ares_sysconfig_files.c +839 -0
  1883. data/third_party/cares/cares/src/lib/ares_sysconfig_mac.c +373 -0
  1884. data/third_party/cares/cares/src/lib/ares_sysconfig_win.c +621 -0
  1885. data/third_party/cares/cares/src/lib/ares_timeout.c +136 -73
  1886. data/third_party/cares/cares/src/lib/ares_update_servers.c +1362 -0
  1887. data/third_party/cares/cares/src/lib/ares_version.c +29 -4
  1888. data/third_party/cares/cares/src/lib/config-dos.h +88 -89
  1889. data/third_party/cares/cares/src/lib/config-win32.h +122 -77
  1890. data/third_party/cares/cares/src/lib/dsa/ares_array.c +394 -0
  1891. data/third_party/cares/cares/src/lib/dsa/ares_htable.c +447 -0
  1892. data/third_party/cares/cares/src/lib/dsa/ares_htable.h +174 -0
  1893. data/third_party/cares/cares/src/lib/dsa/ares_htable_asvp.c +224 -0
  1894. data/third_party/cares/cares/src/lib/dsa/ares_htable_dict.c +228 -0
  1895. data/third_party/cares/cares/src/lib/dsa/ares_htable_strvp.c +210 -0
  1896. data/third_party/cares/cares/src/lib/dsa/ares_htable_szvp.c +188 -0
  1897. data/third_party/cares/cares/src/lib/dsa/ares_htable_vpstr.c +186 -0
  1898. data/third_party/cares/cares/src/lib/dsa/ares_htable_vpvp.c +194 -0
  1899. data/third_party/cares/cares/src/lib/dsa/ares_llist.c +382 -0
  1900. data/third_party/cares/cares/src/lib/dsa/ares_slist.c +479 -0
  1901. data/third_party/cares/cares/src/lib/dsa/ares_slist.h +207 -0
  1902. data/third_party/cares/cares/src/lib/event/ares_event.h +191 -0
  1903. data/third_party/cares/cares/src/lib/event/ares_event_configchg.c +743 -0
  1904. data/third_party/cares/cares/src/lib/event/ares_event_epoll.c +192 -0
  1905. data/third_party/cares/cares/src/lib/event/ares_event_kqueue.c +248 -0
  1906. data/third_party/cares/cares/src/lib/event/ares_event_poll.c +140 -0
  1907. data/third_party/cares/cares/src/lib/event/ares_event_select.c +159 -0
  1908. data/third_party/cares/cares/src/lib/event/ares_event_thread.c +567 -0
  1909. data/third_party/cares/cares/src/lib/event/ares_event_wake_pipe.c +166 -0
  1910. data/third_party/cares/cares/src/lib/event/ares_event_win32.c +978 -0
  1911. data/third_party/cares/cares/src/lib/event/ares_event_win32.h +161 -0
  1912. data/third_party/cares/cares/src/lib/include/ares_array.h +276 -0
  1913. data/third_party/cares/cares/src/lib/include/ares_buf.h +732 -0
  1914. data/third_party/cares/cares/src/lib/include/ares_htable_asvp.h +130 -0
  1915. data/third_party/cares/cares/src/lib/include/ares_htable_dict.h +123 -0
  1916. data/third_party/cares/cares/src/lib/include/ares_htable_strvp.h +130 -0
  1917. data/third_party/cares/cares/src/lib/include/ares_htable_szvp.h +118 -0
  1918. data/third_party/cares/cares/src/lib/include/ares_htable_vpstr.h +111 -0
  1919. data/third_party/cares/cares/src/lib/include/ares_htable_vpvp.h +128 -0
  1920. data/third_party/cares/cares/src/lib/include/ares_llist.h +239 -0
  1921. data/third_party/cares/cares/src/lib/include/ares_mem.h +38 -0
  1922. data/third_party/cares/cares/src/lib/include/ares_str.h +244 -0
  1923. data/third_party/cares/cares/src/lib/inet_net_pton.c +202 -157
  1924. data/third_party/cares/cares/src/lib/inet_ntop.c +87 -69
  1925. data/third_party/cares/cares/src/lib/legacy/ares_create_query.c +78 -0
  1926. data/third_party/cares/cares/src/lib/legacy/ares_expand_name.c +99 -0
  1927. data/third_party/cares/cares/src/lib/legacy/ares_expand_string.c +107 -0
  1928. data/third_party/cares/cares/src/lib/legacy/ares_fds.c +80 -0
  1929. data/third_party/cares/cares/src/lib/legacy/ares_getsock.c +85 -0
  1930. data/third_party/cares/cares/src/lib/legacy/ares_parse_a_reply.c +107 -0
  1931. data/third_party/cares/cares/src/lib/legacy/ares_parse_aaaa_reply.c +109 -0
  1932. data/third_party/cares/cares/src/lib/legacy/ares_parse_caa_reply.c +137 -0
  1933. data/third_party/cares/cares/src/lib/legacy/ares_parse_mx_reply.c +110 -0
  1934. data/third_party/cares/cares/src/lib/legacy/ares_parse_naptr_reply.c +132 -0
  1935. data/third_party/cares/cares/src/lib/legacy/ares_parse_ns_reply.c +154 -0
  1936. data/third_party/cares/cares/src/lib/legacy/ares_parse_ptr_reply.c +213 -0
  1937. data/third_party/cares/cares/src/lib/legacy/ares_parse_soa_reply.c +115 -0
  1938. data/third_party/cares/cares/src/lib/legacy/ares_parse_srv_reply.c +114 -0
  1939. data/third_party/cares/cares/src/lib/legacy/ares_parse_txt_reply.c +144 -0
  1940. data/third_party/cares/cares/src/lib/legacy/ares_parse_uri_reply.c +113 -0
  1941. data/third_party/cares/cares/src/lib/record/ares_dns_mapping.c +982 -0
  1942. data/third_party/cares/cares/src/lib/record/ares_dns_multistring.c +307 -0
  1943. data/third_party/cares/cares/src/lib/record/ares_dns_multistring.h +72 -0
  1944. data/third_party/cares/cares/src/lib/record/ares_dns_name.c +673 -0
  1945. data/third_party/cares/cares/src/lib/record/ares_dns_parse.c +1329 -0
  1946. data/third_party/cares/cares/src/lib/record/ares_dns_private.h +273 -0
  1947. data/third_party/cares/cares/src/lib/record/ares_dns_record.c +1661 -0
  1948. data/third_party/cares/cares/src/lib/record/ares_dns_write.c +1229 -0
  1949. data/third_party/cares/cares/src/lib/str/ares_buf.c +1498 -0
  1950. data/third_party/cares/cares/src/lib/str/ares_str.c +508 -0
  1951. data/third_party/cares/cares/src/lib/str/ares_strsplit.c +90 -0
  1952. data/third_party/cares/cares/src/lib/str/ares_strsplit.h +51 -0
  1953. data/third_party/cares/cares/src/lib/thirdparty/apple/dnsinfo.h +122 -0
  1954. data/third_party/cares/cares/src/lib/util/ares_iface_ips.c +628 -0
  1955. data/third_party/cares/cares/src/lib/util/ares_iface_ips.h +139 -0
  1956. data/third_party/cares/cares/src/lib/util/ares_math.c +158 -0
  1957. data/third_party/cares/cares/src/lib/util/ares_math.h +45 -0
  1958. data/third_party/cares/cares/src/lib/util/ares_rand.c +389 -0
  1959. data/third_party/cares/cares/src/lib/util/ares_rand.h +36 -0
  1960. data/third_party/cares/cares/src/lib/util/ares_threads.c +614 -0
  1961. data/third_party/cares/cares/src/lib/util/ares_threads.h +60 -0
  1962. data/third_party/cares/cares/src/lib/util/ares_time.h +48 -0
  1963. data/third_party/cares/cares/src/lib/util/ares_timeval.c +95 -0
  1964. data/third_party/cares/cares/src/lib/util/ares_uri.c +1626 -0
  1965. data/third_party/cares/cares/src/lib/util/ares_uri.h +252 -0
  1966. data/third_party/cares/cares/src/lib/windows_port.c +16 -9
  1967. data/third_party/upb/upb/hash/common.c +310 -189
  1968. data/third_party/upb/upb/hash/common.h +44 -43
  1969. data/third_party/upb/upb/hash/int_table.h +29 -5
  1970. data/third_party/upb/upb/hash/str_table.h +6 -0
  1971. data/third_party/upb/upb/mem/arena.c +180 -57
  1972. data/third_party/upb/upb/mem/arena.h +10 -0
  1973. data/third_party/upb/upb/mem/internal/arena.h +62 -24
  1974. data/third_party/upb/upb/message/accessors.c +1 -5
  1975. data/third_party/upb/upb/message/array.c +7 -6
  1976. data/third_party/upb/upb/message/array.h +4 -4
  1977. data/third_party/upb/upb/message/internal/accessors.h +3 -3
  1978. data/third_party/upb/upb/message/internal/extension.c +0 -12
  1979. data/third_party/upb/upb/message/internal/extension.h +0 -4
  1980. data/third_party/upb/upb/message/internal/iterator.h +3 -3
  1981. data/third_party/upb/upb/message/internal/map.h +75 -20
  1982. data/third_party/upb/upb/message/internal/map_sorter.h +10 -2
  1983. data/third_party/upb/upb/message/internal/message.h +53 -5
  1984. data/third_party/upb/upb/message/map.c +68 -20
  1985. data/third_party/upb/upb/message/map.h +8 -1
  1986. data/third_party/upb/upb/message/map_gencode_util.h +3 -45
  1987. data/third_party/upb/upb/message/map_sorter.c +32 -8
  1988. data/third_party/upb/upb/message/merge.h +3 -3
  1989. data/third_party/upb/upb/message/message.c +120 -14
  1990. data/third_party/upb/upb/message/message.h +17 -8
  1991. data/third_party/upb/upb/mini_descriptor/build_enum.c +15 -5
  1992. data/third_party/upb/upb/mini_descriptor/decode.c +18 -2
  1993. data/third_party/upb/upb/mini_descriptor/link.c +4 -0
  1994. data/third_party/upb/upb/mini_table/extension.h +8 -1
  1995. data/third_party/upb/upb/mini_table/extension_registry.c +1 -1
  1996. data/third_party/upb/upb/mini_table/internal/enum.h +1 -1
  1997. data/third_party/upb/upb/mini_table/internal/extension.h +24 -1
  1998. data/third_party/upb/upb/mini_table/internal/field.h +4 -4
  1999. data/third_party/upb/upb/mini_table/internal/message.h +1 -1
  2000. data/third_party/upb/upb/port/def.inc +32 -16
  2001. data/third_party/upb/upb/port/undef.inc +1 -0
  2002. data/third_party/upb/upb/reflection/def_pool.h +2 -2
  2003. data/third_party/upb/upb/reflection/descriptor_bootstrap.h +3 -3
  2004. data/third_party/upb/upb/reflection/enum_def.c +4 -4
  2005. data/third_party/upb/upb/reflection/enum_reserved_range.c +1 -1
  2006. data/third_party/upb/upb/reflection/enum_value_def.c +9 -8
  2007. data/third_party/upb/upb/reflection/extension_range.c +1 -2
  2008. data/third_party/upb/upb/reflection/field_def.c +3 -5
  2009. data/third_party/upb/upb/reflection/field_def.h +1 -1
  2010. data/third_party/upb/upb/reflection/file_def.c +4 -5
  2011. data/third_party/upb/upb/reflection/internal/def_builder.h +35 -10
  2012. data/third_party/upb/upb/reflection/internal/enum_value_def.h +1 -1
  2013. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  2014. data/third_party/upb/upb/reflection/message_def.c +4 -7
  2015. data/third_party/upb/upb/reflection/message_reserved_range.c +1 -1
  2016. data/third_party/upb/upb/reflection/method_def.c +1 -1
  2017. data/third_party/upb/upb/reflection/oneof_def.c +3 -3
  2018. data/third_party/upb/upb/reflection/service_def.c +2 -5
  2019. data/third_party/upb/upb/text/encode.c +16 -0
  2020. data/third_party/upb/upb/text/internal/encode.h +2 -1
  2021. data/third_party/upb/upb/wire/decode.c +104 -72
  2022. data/third_party/upb/upb/wire/encode.c +37 -13
  2023. data/third_party/upb/upb/wire/internal/decode_fast.c +2 -2
  2024. data/third_party/upb/upb/wire/internal/decode_fast.h +4 -0
  2025. metadata +298 -79
  2026. data/src/core/lib/event_engine/forkable.cc +0 -105
  2027. data/src/core/lib/event_engine/forkable.h +0 -67
  2028. data/src/core/lib/iomgr/executor.cc +0 -441
  2029. data/src/core/lib/iomgr/executor.h +0 -119
  2030. data/src/core/lib/iomgr/python_util.h +0 -46
  2031. data/src/core/util/ring_buffer.h +0 -122
  2032. data/third_party/abseil-cpp/absl/base/internal/inline_variable.h +0 -108
  2033. data/third_party/abseil-cpp/absl/base/internal/invoke.h +0 -241
  2034. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +0 -108
  2035. data/third_party/abseil-cpp/absl/log/log_entry.cc +0 -41
  2036. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.h +0 -131
  2037. data/third_party/abseil-cpp/absl/types/bad_optional_access.cc +0 -66
  2038. data/third_party/abseil-cpp/absl/types/bad_optional_access.h +0 -78
  2039. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +0 -82
  2040. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +0 -82
  2041. data/third_party/abseil-cpp/absl/types/internal/optional.h +0 -352
  2042. data/third_party/abseil-cpp/absl/types/internal/variant.h +0 -1622
  2043. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/polyval.cc.inc +0 -89
  2044. data/third_party/cares/cares/include/ares_rules.h +0 -125
  2045. data/third_party/cares/cares/src/lib/ares__addrinfo2hostent.c +0 -266
  2046. data/third_party/cares/cares/src/lib/ares__addrinfo_localhost.c +0 -240
  2047. data/third_party/cares/cares/src/lib/ares__close_sockets.c +0 -61
  2048. data/third_party/cares/cares/src/lib/ares__get_hostent.c +0 -260
  2049. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +0 -229
  2050. data/third_party/cares/cares/src/lib/ares__read_line.c +0 -73
  2051. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +0 -258
  2052. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +0 -507
  2053. data/third_party/cares/cares/src/lib/ares__timeval.c +0 -111
  2054. data/third_party/cares/cares/src/lib/ares_create_query.c +0 -197
  2055. data/third_party/cares/cares/src/lib/ares_expand_name.c +0 -311
  2056. data/third_party/cares/cares/src/lib/ares_expand_string.c +0 -67
  2057. data/third_party/cares/cares/src/lib/ares_fds.c +0 -59
  2058. data/third_party/cares/cares/src/lib/ares_getsock.c +0 -66
  2059. data/third_party/cares/cares/src/lib/ares_iphlpapi.h +0 -221
  2060. data/third_party/cares/cares/src/lib/ares_llist.c +0 -63
  2061. data/third_party/cares/cares/src/lib/ares_llist.h +0 -39
  2062. data/third_party/cares/cares/src/lib/ares_mkquery.c +0 -24
  2063. data/third_party/cares/cares/src/lib/ares_nowarn.c +0 -260
  2064. data/third_party/cares/cares/src/lib/ares_nowarn.h +0 -61
  2065. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +0 -90
  2066. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +0 -92
  2067. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +0 -199
  2068. data/third_party/cares/cares/src/lib/ares_parse_mx_reply.c +0 -164
  2069. data/third_party/cares/cares/src/lib/ares_parse_naptr_reply.c +0 -183
  2070. data/third_party/cares/cares/src/lib/ares_parse_ns_reply.c +0 -177
  2071. data/third_party/cares/cares/src/lib/ares_parse_ptr_reply.c +0 -228
  2072. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +0 -179
  2073. data/third_party/cares/cares/src/lib/ares_parse_srv_reply.c +0 -168
  2074. data/third_party/cares/cares/src/lib/ares_parse_txt_reply.c +0 -214
  2075. data/third_party/cares/cares/src/lib/ares_parse_uri_reply.c +0 -184
  2076. data/third_party/cares/cares/src/lib/ares_platform.c +0 -11042
  2077. data/third_party/cares/cares/src/lib/ares_platform.h +0 -43
  2078. data/third_party/cares/cares/src/lib/ares_rand.c +0 -279
  2079. data/third_party/cares/cares/src/lib/ares_strcasecmp.c +0 -66
  2080. data/third_party/cares/cares/src/lib/ares_strcasecmp.h +0 -30
  2081. data/third_party/cares/cares/src/lib/ares_strdup.c +0 -42
  2082. data/third_party/cares/cares/src/lib/ares_strdup.h +0 -24
  2083. data/third_party/cares/cares/src/lib/ares_strsplit.c +0 -94
  2084. data/third_party/cares/cares/src/lib/ares_strsplit.h +0 -42
  2085. data/third_party/cares/cares/src/lib/ares_writev.c +0 -79
  2086. data/third_party/cares/cares/src/lib/ares_writev.h +0 -36
  2087. data/third_party/cares/cares/src/lib/bitncmp.c +0 -59
  2088. data/third_party/cares/cares/src/lib/bitncmp.h +0 -26
  2089. data/third_party/cares/cares/src/lib/setup_once.h +0 -554
  2090. data/third_party/cares/cares/src/tools/ares_getopt.h +0 -53
@@ -33,15 +33,10 @@
33
33
  #include <type_traits>
34
34
  #include <utility>
35
35
 
36
- #include "absl/container/inlined_vector.h"
37
- #include "absl/functional/function_ref.h"
38
- #include "absl/log/check.h"
39
- #include "absl/log/log.h"
40
- #include "absl/meta/type_traits.h"
41
- #include "absl/status/status.h"
42
- #include "absl/strings/string_view.h"
43
36
  #include "src/core/call/call_filters.h"
44
37
  #include "src/core/call/call_finalization.h"
38
+ #include "src/core/call/message.h"
39
+ #include "src/core/call/metadata.h"
45
40
  #include "src/core/call/metadata_batch.h"
46
41
  #include "src/core/filter/blackboard.h"
47
42
  #include "src/core/filter/filter_args.h"
@@ -59,6 +54,7 @@
59
54
  #include "src/core/lib/promise/arena_promise.h"
60
55
  #include "src/core/lib/promise/cancel_callback.h"
61
56
  #include "src/core/lib/promise/context.h"
57
+ #include "src/core/lib/promise/detail/promise_like.h"
62
58
  #include "src/core/lib/promise/pipe.h"
63
59
  #include "src/core/lib/promise/poll.h"
64
60
  #include "src/core/lib/promise/promise.h"
@@ -70,8 +66,15 @@
70
66
  #include "src/core/lib/transport/error_utils.h"
71
67
  #include "src/core/lib/transport/transport.h"
72
68
  #include "src/core/util/debug_location.h"
69
+ #include "src/core/util/grpc_check.h"
73
70
  #include "src/core/util/match.h"
74
71
  #include "src/core/util/time.h"
72
+ #include "absl/container/inlined_vector.h"
73
+ #include "absl/functional/function_ref.h"
74
+ #include "absl/log/log.h"
75
+ #include "absl/meta/type_traits.h"
76
+ #include "absl/status/status.h"
77
+ #include "absl/strings/string_view.h"
75
78
 
76
79
  namespace grpc_core {
77
80
 
@@ -108,55 +111,96 @@ namespace promise_filter_detail {
108
111
  // the promise. If so, we need to allocate a latch for the generated promise for
109
112
  // the original promise stack polyfill code that's generated.
110
113
 
111
- inline constexpr bool HasAsyncErrorInterceptor() { return false; }
114
+ template <typename T>
115
+ using EnableIfPromise = std::enable_if_t<std::is_invocable_v<T>, void>;
112
116
 
113
- inline constexpr bool HasAsyncErrorInterceptor(const NoInterceptor*) {
114
- return false;
115
- }
117
+ template <typename R, typename Ignored = void>
118
+ struct HasAsyncErrorInterceptor;
119
+
120
+ template <>
121
+ struct HasAsyncErrorInterceptor<void> {
122
+ static constexpr bool value = false;
123
+ };
124
+
125
+ template <>
126
+ struct HasAsyncErrorInterceptor<const NoInterceptor*> {
127
+ static constexpr bool value = false;
128
+ };
116
129
 
117
130
  template <typename T, typename A0, typename... As>
118
- inline constexpr bool HasAsyncErrorInterceptor(A0 (T::*)(A0, As...)) {
119
- return false;
120
- }
131
+ struct HasAsyncErrorInterceptor<A0 (T::*)(A0, As...)> {
132
+ static constexpr bool value = false;
133
+ };
121
134
 
122
135
  template <typename T, typename... A>
123
- inline constexpr bool HasAsyncErrorInterceptor(absl::Status (T::*)(A...)) {
124
- return true;
125
- }
136
+ struct HasAsyncErrorInterceptor<absl::Status (T::*)(A...)> {
137
+ static constexpr bool value = true;
138
+ };
126
139
 
127
140
  template <typename R, typename T, typename... A>
128
- inline constexpr bool HasAsyncErrorInterceptor(absl::StatusOr<R> (T::*)(A...)) {
129
- return true;
130
- }
141
+ struct HasAsyncErrorInterceptor<absl::StatusOr<R> (T::*)(A...)> {
142
+ static constexpr bool value = true;
143
+ };
131
144
 
132
145
  template <typename T, typename... A>
133
- inline constexpr bool HasAsyncErrorInterceptor(
134
- ServerMetadataHandle (T::*)(A...)) {
135
- return true;
136
- }
146
+ struct HasAsyncErrorInterceptor<ServerMetadataHandle (T::*)(A...)> {
147
+ static constexpr bool value = true;
148
+ };
137
149
 
138
150
  template <typename T, typename... A>
139
- inline constexpr bool HasAsyncErrorInterceptor(void (T::*)(A...)) {
140
- return false;
141
- }
151
+ struct HasAsyncErrorInterceptor<void (T::*)(A...)> {
152
+ static constexpr bool value = false;
153
+ };
154
+
155
+ template <typename T, typename Promise, typename... A>
156
+ struct HasAsyncErrorInterceptor<Promise (T::*)(A...),
157
+ EnableIfPromise<Promise>> {
158
+ // TODO(vigneshbabu): - For fused filters, this should be the OR of
159
+ // HasAsyncErrorInterceptor of all constituent filters.
160
+ static constexpr bool value = true;
161
+ };
142
162
 
143
163
  // For the list case we do two interceptors to avoid amiguities with the single
144
164
  // argument forms above.
145
- template <typename I1, typename I2, typename... Interceptors>
146
- inline constexpr bool HasAsyncErrorInterceptor(I1 i1, I2 i2,
147
- Interceptors... interceptors) {
148
- return HasAsyncErrorInterceptor(i1) || HasAsyncErrorInterceptor(i2) ||
149
- HasAsyncErrorInterceptor(interceptors...);
165
+ template <typename... Interceptors>
166
+ inline constexpr bool HasAnyAsyncErrorInterceptor(Interceptors...) {
167
+ return (HasAsyncErrorInterceptor<Interceptors>::value || ...);
150
168
  }
151
169
 
170
+ // value is true if Derived has a member called IsFused.
171
+ template <typename Derived>
172
+ struct IsFusedFilter {
173
+ template <typename V>
174
+ static std::true_type test(decltype(&V::IsFused)); // SFINAE context
175
+ template <typename V>
176
+ static std::false_type test(...);
177
+
178
+ using type = decltype(test<Derived>(nullptr));
179
+ static constexpr bool value = std::is_same_v<type, std::true_type>;
180
+ };
181
+
182
+ template <typename Derived, typename Ignored = void>
183
+ struct CallHasAsyncErrorInterceptor;
184
+
152
185
  // Composite for a given channel type to determine if any of its interceptors
153
186
  // fall into this category: later code should use this.
154
187
  template <typename Derived>
155
- inline constexpr bool CallHasAsyncErrorInterceptor() {
156
- return HasAsyncErrorInterceptor(&Derived::Call::OnClientToServerMessage,
188
+ struct CallHasAsyncErrorInterceptor<
189
+ Derived, std::enable_if_t<!IsFusedFilter<Derived>::value>> {
190
+ static constexpr bool value =
191
+ HasAnyAsyncErrorInterceptor(&Derived::Call::OnClientToServerMessage,
157
192
  &Derived::Call::OnServerInitialMetadata,
158
193
  &Derived::Call::OnServerToClientMessage);
159
- }
194
+ };
195
+
196
+ template <typename Derived>
197
+ struct CallHasAsyncErrorInterceptor<
198
+ Derived, std::enable_if_t<IsFusedFilter<Derived>::value>> {
199
+ // Fused filter types return a promise, which resolves to a
200
+ // ServerMetadataHandle type. So we assume that an async error interceptor is
201
+ // always needed.
202
+ static constexpr bool value = true;
203
+ };
160
204
 
161
205
  // Given a boolean X export a type:
162
206
  // either T if X is true
@@ -196,7 +240,7 @@ struct RaceAsyncCompletion<false> {
196
240
  template <>
197
241
  struct RaceAsyncCompletion<true> {
198
242
  template <typename Promise>
199
- static Promise Run(Promise x, Latch<ServerMetadataHandle>* latch) {
243
+ static auto Run(Promise x, Latch<ServerMetadataHandle>* latch) {
200
244
  return Race(latch->Wait(), std::move(x));
201
245
  }
202
246
  };
@@ -228,7 +272,7 @@ struct FilterCallData {
228
272
  GPR_NO_UNIQUE_ADDRESS CallWrapper<Derived> call;
229
273
  GPR_NO_UNIQUE_ADDRESS
230
274
  typename TypeIfNeeded<Latch<ServerMetadataHandle>,
231
- CallHasAsyncErrorInterceptor<Derived>()>::Type
275
+ CallHasAsyncErrorInterceptor<Derived>::value>::Type
232
276
  error_latch;
233
277
  GPR_NO_UNIQUE_ADDRESS
234
278
  typename TypeIfNeeded<
@@ -243,7 +287,7 @@ auto MapResult(const NoInterceptor*, Promise x, void*) {
243
287
  template <typename Promise, typename Derived>
244
288
  auto MapResult(absl::Status (Derived::Call::*fn)(ServerMetadata&), Promise x,
245
289
  FilterCallData<Derived>* call_data) {
246
- DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
290
+ GRPC_DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
247
291
  return OnCancel(Map(std::move(x),
248
292
  [call_data](ServerMetadataHandle md) {
249
293
  auto status =
@@ -264,7 +308,7 @@ auto MapResult(absl::Status (Derived::Call::*fn)(ServerMetadata&), Promise x,
264
308
  template <typename Promise, typename Derived>
265
309
  auto MapResult(void (Derived::Call::*fn)(ServerMetadata&), Promise x,
266
310
  FilterCallData<Derived>* call_data) {
267
- DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
311
+ GRPC_DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
268
312
  return OnCancel(Map(std::move(x),
269
313
  [call_data](ServerMetadataHandle md) {
270
314
  call_data->call.OnServerTrailingMetadata(*md);
@@ -281,7 +325,28 @@ auto MapResult(void (Derived::Call::*fn)(ServerMetadata&), Promise x,
281
325
  template <typename Promise, typename Derived>
282
326
  auto MapResult(void (Derived::Call::*fn)(ServerMetadata&, Derived*), Promise x,
283
327
  FilterCallData<Derived>* call_data) {
284
- DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
328
+ GRPC_DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
329
+ return OnCancel(
330
+ Map(std::move(x),
331
+ [call_data](ServerMetadataHandle md) {
332
+ call_data->call.OnServerTrailingMetadata(*md, call_data->channel);
333
+ return md;
334
+ }),
335
+ [call_data]() {
336
+ grpc_metadata_batch b;
337
+ b.Set(GrpcStatusMetadata(), GRPC_STATUS_CANCELLED);
338
+ b.Set(GrpcCallWasCancelled(), true);
339
+ call_data->call.OnServerTrailingMetadata(b, call_data->channel);
340
+ });
341
+ }
342
+
343
+ // For fused filters whose OnServerTrailingMetadata takes pointer to the
344
+ // channel.
345
+ template <typename P, typename Call, typename Derived,
346
+ typename = std::enable_if_t<IsFusedFilter<Derived>::value>>
347
+ auto MapResult(void (Call::*fn)(ServerMetadata&, Derived*), P x,
348
+ FilterCallData<Derived>* call_data) {
349
+ GRPC_DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
285
350
  return OnCancel(
286
351
  Map(std::move(x),
287
352
  [call_data](ServerMetadataHandle md) {
@@ -296,6 +361,40 @@ auto MapResult(void (Derived::Call::*fn)(ServerMetadata&, Derived*), Promise x,
296
361
  });
297
362
  }
298
363
 
364
+ // For fused filters whose OnServerTrailingMetadata does not take pointer to the
365
+ // channel.
366
+ template <typename P, typename Call, typename Derived,
367
+ typename = std::enable_if_t<IsFusedFilter<Derived>::value>>
368
+ auto MapResult(void (Call::*fn)(ServerMetadata&), P x,
369
+ FilterCallData<Derived>* call_data) {
370
+ GRPC_DCHECK(fn == &Derived::Call::OnServerTrailingMetadata);
371
+ return OnCancel(Map(std::move(x),
372
+ [call_data](ServerMetadataHandle md) {
373
+ call_data->call.OnServerTrailingMetadata(*md);
374
+ return md;
375
+ }),
376
+ [call_data]() {
377
+ grpc_metadata_batch b;
378
+ b.Set(GrpcStatusMetadata(), GRPC_STATUS_CANCELLED);
379
+ b.Set(GrpcCallWasCancelled(), true);
380
+ call_data->call.OnServerTrailingMetadata(b);
381
+ });
382
+ }
383
+
384
+ template <typename T, typename A>
385
+ constexpr bool IsSameExcludingCVRef =
386
+ std::is_same<promise_detail::RemoveCVRef<A>, T>::value;
387
+
388
+ template <typename T, typename A>
389
+ using EnableIfSameExcludingCVRef =
390
+ std::enable_if_t<std::is_same<promise_detail::RemoveCVRef<A>, T>::value,
391
+ void>;
392
+
393
+ template <typename T, typename A>
394
+ using EnableIfNotSameExcludingCVRef =
395
+ std::enable_if_t<!std::is_same<promise_detail::RemoveCVRef<A>, T>::value,
396
+ void>;
397
+
299
398
  template <typename Interceptor, typename Derived, typename SfinaeVoid = void>
300
399
  struct RunCallImpl;
301
400
 
@@ -307,8 +406,9 @@ struct RunCallImpl<const NoInterceptor*, Derived> {
307
406
  }
308
407
  };
309
408
 
310
- template <typename Derived>
311
- struct RunCallImpl<void (Derived::Call::*)(ClientMetadata& md), Derived> {
409
+ template <typename Derived, typename A>
410
+ struct RunCallImpl<void (Derived::Call::*)(A md), Derived,
411
+ EnableIfSameExcludingCVRef<ClientMetadata, A>> {
312
412
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
313
413
  FilterCallData<Derived>* call_data) {
314
414
  call_data->call.OnClientInitialMetadata(*call_args.client_initial_metadata);
@@ -316,9 +416,9 @@ struct RunCallImpl<void (Derived::Call::*)(ClientMetadata& md), Derived> {
316
416
  }
317
417
  };
318
418
 
319
- template <typename Derived>
320
- struct RunCallImpl<ServerMetadataHandle (Derived::Call::*)(ClientMetadata& md),
321
- Derived> {
419
+ template <typename Derived, typename A>
420
+ struct RunCallImpl<ServerMetadataHandle (Derived::Call::*)(A md), Derived,
421
+ EnableIfSameExcludingCVRef<ClientMetadata, A>> {
322
422
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
323
423
  FilterCallData<Derived>* call_data)
324
424
  -> ArenaPromise<ServerMetadataHandle> {
@@ -329,10 +429,10 @@ struct RunCallImpl<ServerMetadataHandle (Derived::Call::*)(ClientMetadata& md),
329
429
  }
330
430
  };
331
431
 
332
- template <typename Derived>
333
- struct RunCallImpl<ServerMetadataHandle (Derived::Call::*)(ClientMetadata& md,
432
+ template <typename Derived, typename A>
433
+ struct RunCallImpl<ServerMetadataHandle (Derived::Call::*)(A md,
334
434
  Derived* channel),
335
- Derived> {
435
+ Derived, EnableIfSameExcludingCVRef<ClientMetadata, A>> {
336
436
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
337
437
  FilterCallData<Derived>* call_data)
338
438
  -> ArenaPromise<ServerMetadataHandle> {
@@ -343,9 +443,9 @@ struct RunCallImpl<ServerMetadataHandle (Derived::Call::*)(ClientMetadata& md,
343
443
  }
344
444
  };
345
445
 
346
- template <typename Derived>
347
- struct RunCallImpl<absl::Status (Derived::Call::*)(ClientMetadata& md),
348
- Derived> {
446
+ template <typename Derived, typename A>
447
+ struct RunCallImpl<absl::Status (Derived::Call::*)(A md), Derived,
448
+ EnableIfSameExcludingCVRef<ClientMetadata, A>> {
349
449
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
350
450
  FilterCallData<Derived>* call_data)
351
451
  -> ArenaPromise<ServerMetadataHandle> {
@@ -356,10 +456,9 @@ struct RunCallImpl<absl::Status (Derived::Call::*)(ClientMetadata& md),
356
456
  }
357
457
  };
358
458
 
359
- template <typename Derived>
360
- struct RunCallImpl<absl::Status (Derived::Call::*)(ClientMetadata& md,
361
- Derived* channel),
362
- Derived> {
459
+ template <typename Derived, typename A>
460
+ struct RunCallImpl<absl::Status (Derived::Call::*)(A md, Derived* channel),
461
+ Derived, EnableIfSameExcludingCVRef<ClientMetadata, A>> {
363
462
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
364
463
  FilterCallData<Derived>* call_data)
365
464
  -> ArenaPromise<ServerMetadataHandle> {
@@ -370,9 +469,9 @@ struct RunCallImpl<absl::Status (Derived::Call::*)(ClientMetadata& md,
370
469
  }
371
470
  };
372
471
 
373
- template <typename Derived>
374
- struct RunCallImpl<
375
- void (Derived::Call::*)(ClientMetadata& md, Derived* channel), Derived> {
472
+ template <typename Derived, typename A>
473
+ struct RunCallImpl<void (Derived::Call::*)(A md, Derived* channel), Derived,
474
+ EnableIfSameExcludingCVRef<ClientMetadata, A>> {
376
475
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
377
476
  FilterCallData<Derived>* call_data) {
378
477
  call_data->call.OnClientInitialMetadata(*call_args.client_initial_metadata,
@@ -381,11 +480,22 @@ struct RunCallImpl<
381
480
  }
382
481
  };
383
482
 
384
- template <typename Derived, typename Promise>
385
- struct RunCallImpl<
386
- Promise (Derived::Call::*)(ClientMetadata& md, Derived* channel), Derived,
387
- absl::void_t<decltype(StatusCast<ServerMetadataHandle>(
388
- std::declval<PromiseResult<Promise>>))>> {
483
+ template <typename T, typename AnyType = void>
484
+ struct StatusCastExistsToServerMetadataHandle {
485
+ static constexpr bool value = false;
486
+ };
487
+ template <typename T>
488
+ struct StatusCastExistsToServerMetadataHandle<
489
+ T,
490
+ absl::void_t<decltype(StatusCast<ServerMetadataHandle>(std::declval<T>))>> {
491
+ static constexpr bool value = true;
492
+ };
493
+
494
+ template <typename Derived, typename A, typename Promise>
495
+ struct RunCallImpl<Promise (Derived::Call::*)(A, Derived* channel), Derived,
496
+ std::enable_if_t<StatusCastExistsToServerMetadataHandle<
497
+ PromiseResult<Promise>>::value &&
498
+ IsSameExcludingCVRef<ClientMetadata, A>>> {
389
499
  static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
390
500
  FilterCallData<Derived>* call_data) {
391
501
  ClientMetadata& md_ref = *call_args.client_initial_metadata;
@@ -418,288 +528,582 @@ struct RunCallImpl<
418
528
  }
419
529
  };
420
530
 
531
+ template <typename Derived, typename Call, typename Promise>
532
+ struct RunCallImpl<
533
+ Promise (Call::*)(ClientMetadataHandle md, Derived* channel), Derived,
534
+ std::enable_if_t<std::is_same_v<PromiseResult<Promise>,
535
+ ServerMetadataOrHandle<ClientMetadata>>,
536
+ void>> {
537
+ static auto Run(CallArgs call_args, NextPromiseFactory next_promise_factory,
538
+ FilterCallData<Derived>* call_data) {
539
+ ClientMetadataHandle md = std::move(call_args.client_initial_metadata);
540
+ return TrySeq(call_data->call.OnClientInitialMetadata(std::move(md),
541
+ call_data->channel),
542
+ [call_args = std::move(call_args),
543
+ next_promise_factory = std::move(next_promise_factory)](
544
+ ClientMetadataHandle md) mutable {
545
+ call_args.client_initial_metadata = std::move(md);
546
+ return next_promise_factory(std::move(call_args));
547
+ });
548
+ }
549
+ };
550
+
421
551
  template <typename Interceptor, typename Derived>
422
552
  auto RunCall(Interceptor interceptor, CallArgs call_args,
423
553
  NextPromiseFactory next_promise_factory,
424
554
  FilterCallData<Derived>* call_data) {
425
- DCHECK(interceptor == &Derived::Call::OnClientInitialMetadata);
555
+ GRPC_DCHECK(interceptor == &Derived::Call::OnClientInitialMetadata);
426
556
  return RunCallImpl<Interceptor, Derived>::Run(
427
557
  std::move(call_args), std::move(next_promise_factory), call_data);
428
558
  }
429
559
 
430
- template <typename Derived>
431
- inline auto InterceptClientToServerMessageHandler(
432
- void (Derived::Call::*fn)(const Message&),
433
- FilterCallData<Derived>* call_data, const CallArgs&) {
434
- DCHECK(fn == &Derived::Call::OnClientToServerMessage);
435
- return [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
436
- call_data->call.OnClientToServerMessage(*msg);
437
- return std::move(msg);
438
- };
439
- }
560
+ template <typename Derived, typename MethodType, typename Ignored = void>
561
+ class InterceptClientToServerMessageHandler;
440
562
 
441
563
  template <typename Derived>
442
- inline auto InterceptClientToServerMessageHandler(
443
- ServerMetadataHandle (Derived::Call::*fn)(const Message&),
444
- FilterCallData<Derived>* call_data, const CallArgs&) {
445
- DCHECK(fn == &Derived::Call::OnClientToServerMessage);
446
- return [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
447
- auto return_md = call_data->call.OnClientToServerMessage(*msg);
448
- if (return_md == nullptr) return std::move(msg);
449
- if (call_data->error_latch.is_set()) return std::nullopt;
450
- call_data->error_latch.Set(std::move(return_md));
451
- return std::nullopt;
452
- };
453
- }
564
+ class InterceptClientToServerMessageHandler<Derived, const NoInterceptor*> {
565
+ public:
566
+ explicit InterceptClientToServerMessageHandler(FilterCallData<Derived>*,
567
+ const CallArgs&) {}
568
+ auto operator()() {
569
+ return [](MessageHandle msg) -> std::optional<MessageHandle> {
570
+ return std::move(msg);
571
+ };
572
+ }
573
+ };
454
574
 
455
- template <typename Derived>
456
- inline auto InterceptClientToServerMessageHandler(
457
- ServerMetadataHandle (Derived::Call::*fn)(const Message&, Derived*),
458
- FilterCallData<Derived>* call_data, const CallArgs&) {
459
- DCHECK(fn == &Derived::Call::OnClientToServerMessage);
460
- return [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
461
- auto return_md =
462
- call_data->call.OnClientToServerMessage(*msg, call_data->channel);
463
- if (return_md == nullptr) return std::move(msg);
464
- if (call_data->error_latch.is_set()) return std::nullopt;
465
- call_data->error_latch.Set(std::move(return_md));
466
- return std::nullopt;
467
- };
468
- }
575
+ template <typename Derived, typename MessageType>
576
+ class InterceptClientToServerMessageHandler<
577
+ Derived, void (Derived::Call::*)(MessageType),
578
+ EnableIfSameExcludingCVRef<Message, MessageType>> {
579
+ public:
580
+ explicit InterceptClientToServerMessageHandler(
581
+ FilterCallData<Derived>* call_data, const CallArgs&)
582
+ : call_data_(call_data) {}
583
+ auto operator()() {
584
+ return [call_data =
585
+ call_data_](MessageHandle msg) -> std::optional<MessageHandle> {
586
+ call_data->call.OnClientToServerMessage(*msg);
587
+ return std::move(msg);
588
+ };
589
+ }
469
590
 
470
- template <typename Derived>
471
- inline auto InterceptClientToServerMessageHandler(
472
- void (Derived::Call::*fn)(const Message&, Derived*),
473
- FilterCallData<Derived>* call_data, const CallArgs&) {
474
- DCHECK(fn == &Derived::Call::OnClientToServerMessage);
475
- return [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
476
- call_data->call.OnClientToServerMessage(*msg, call_data->channel);
477
- return std::move(msg);
478
- };
479
- }
591
+ private:
592
+ FilterCallData<Derived>* call_data_;
593
+ };
480
594
 
481
- template <typename Derived>
482
- inline auto InterceptClientToServerMessageHandler(
483
- MessageHandle (Derived::Call::*fn)(MessageHandle, Derived*),
484
- FilterCallData<Derived>* call_data, const CallArgs&) {
485
- DCHECK(fn == &Derived::Call::OnClientToServerMessage);
486
- return [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
487
- return call_data->call.OnClientToServerMessage(std::move(msg),
488
- call_data->channel);
489
- };
490
- }
595
+ template <typename Derived, typename MessageType>
596
+ class InterceptClientToServerMessageHandler<
597
+ Derived, ServerMetadataHandle (Derived::Call::*)(MessageType),
598
+ EnableIfSameExcludingCVRef<Message, MessageType>> {
599
+ public:
600
+ explicit InterceptClientToServerMessageHandler(
601
+ FilterCallData<Derived>* call_data, const CallArgs&)
602
+ : call_data_(call_data) {}
603
+
604
+ auto operator()() {
605
+ return [call_data =
606
+ call_data_](MessageHandle msg) -> std::optional<MessageHandle> {
607
+ auto return_md = call_data->call.OnClientToServerMessage(*msg);
608
+ if (return_md == nullptr) return std::move(msg);
609
+ if (call_data->error_latch.is_set()) return std::nullopt;
610
+ call_data->error_latch.Set(std::move(return_md));
611
+ return std::nullopt;
612
+ };
613
+ }
614
+
615
+ private:
616
+ FilterCallData<Derived>* call_data_;
617
+ };
618
+
619
+ template <typename Derived, typename MessageType>
620
+ class InterceptClientToServerMessageHandler<
621
+ Derived, ServerMetadataHandle (Derived::Call::*)(MessageType, Derived*),
622
+ EnableIfSameExcludingCVRef<Message, MessageType>> {
623
+ public:
624
+ explicit InterceptClientToServerMessageHandler(
625
+ FilterCallData<Derived>* call_data, const CallArgs&)
626
+ : call_data_(call_data) {}
627
+
628
+ auto operator()() {
629
+ return [call_data =
630
+ call_data_](MessageHandle msg) -> std::optional<MessageHandle> {
631
+ auto return_md =
632
+ call_data->call.OnClientToServerMessage(*msg, call_data->channel);
633
+ if (return_md == nullptr) return std::move(msg);
634
+ if (call_data->error_latch.is_set()) return std::nullopt;
635
+ call_data->error_latch.Set(std::move(return_md));
636
+ return std::nullopt;
637
+ };
638
+ }
639
+
640
+ private:
641
+ FilterCallData<Derived>* call_data_;
642
+ };
643
+
644
+ template <typename Derived, typename MessageType>
645
+ class InterceptClientToServerMessageHandler<
646
+ Derived, void (Derived::Call::*)(MessageType, Derived*),
647
+ EnableIfSameExcludingCVRef<Message, MessageType>> {
648
+ public:
649
+ explicit InterceptClientToServerMessageHandler(
650
+ FilterCallData<Derived>* call_data, const CallArgs&)
651
+ : call_data_(call_data) {}
652
+
653
+ auto operator()() {
654
+ return [call_data =
655
+ call_data_](MessageHandle msg) -> std::optional<MessageHandle> {
656
+ call_data->call.OnClientToServerMessage(*msg, call_data->channel);
657
+ return std::move(msg);
658
+ };
659
+ }
660
+
661
+ private:
662
+ FilterCallData<Derived>* call_data_;
663
+ };
491
664
 
492
665
  template <typename Derived>
493
- inline auto InterceptClientToServerMessageHandler(
494
- absl::StatusOr<MessageHandle> (Derived::Call::*fn)(MessageHandle, Derived*),
495
- FilterCallData<Derived>* call_data, const CallArgs&) {
496
- DCHECK(fn == &Derived::Call::OnClientToServerMessage);
497
- return [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
498
- auto r = call_data->call.OnClientToServerMessage(std::move(msg),
666
+ class InterceptClientToServerMessageHandler<
667
+ Derived, MessageHandle (Derived::Call::*)(MessageHandle, Derived*)> {
668
+ public:
669
+ explicit InterceptClientToServerMessageHandler(
670
+ FilterCallData<Derived>* call_data, const CallArgs&)
671
+ : call_data_(call_data) {}
672
+
673
+ auto operator()() {
674
+ return [call_data =
675
+ call_data_](MessageHandle msg) -> std::optional<MessageHandle> {
676
+ return call_data->call.OnClientToServerMessage(std::move(msg),
499
677
  call_data->channel);
500
- if (r.ok()) return std::move(*r);
501
- if (call_data->error_latch.is_set()) return std::nullopt;
502
- call_data->error_latch.Set(ServerMetadataFromStatus(r.status()));
503
- return std::nullopt;
504
- };
505
- }
678
+ };
679
+ }
506
680
 
507
- template <typename Derived, typename HookFunction>
508
- inline void InterceptClientToServerMessage(HookFunction hook,
509
- const NoInterceptor*,
510
- FilterCallData<Derived>* call_data,
511
- const CallArgs& call_args) {
512
- call_args.client_to_server_messages->InterceptAndMap(
513
- InterceptClientToServerMessageHandler(hook, call_data, call_args));
514
- }
681
+ private:
682
+ FilterCallData<Derived>* call_data_;
683
+ };
515
684
 
516
- template <typename Derived, typename HookFunction>
517
- inline void InterceptClientToServerMessage(HookFunction hook,
518
- void (Derived::Call::*)(),
519
- FilterCallData<Derived>* call_data,
520
- const CallArgs& call_args) {
521
- call_args.client_to_server_messages->InterceptAndMapWithHalfClose(
522
- InterceptClientToServerMessageHandler(hook, call_data, call_args),
523
- [call_data]() { call_data->call.OnClientToServerHalfClose(); });
524
- }
685
+ template <typename Derived>
686
+ class InterceptClientToServerMessageHandler<
687
+ Derived,
688
+ absl::StatusOr<MessageHandle> (Derived::Call::*)(MessageHandle, Derived*)> {
689
+ public:
690
+ explicit InterceptClientToServerMessageHandler(
691
+ FilterCallData<Derived>* call_data, const CallArgs&)
692
+ : call_data_(call_data) {}
693
+
694
+ auto operator()() {
695
+ return [call_data =
696
+ call_data_](MessageHandle msg) -> std::optional<MessageHandle> {
697
+ auto r = call_data->call.OnClientToServerMessage(std::move(msg),
698
+ call_data->channel);
699
+ if (r.ok()) return std::move(*r);
700
+ if (call_data->error_latch.is_set()) return std::nullopt;
701
+ call_data->error_latch.Set(ServerMetadataFromStatus(r.status()));
702
+ return std::nullopt;
703
+ };
704
+ }
705
+
706
+ private:
707
+ FilterCallData<Derived>* call_data_;
708
+ };
709
+
710
+ // For handling fused filters with a promise return type. This specialization is
711
+ // only for fused filters not requiring a channel pointer.
712
+ template <typename Derived, typename R, typename Call>
713
+ class InterceptClientToServerMessageHandler<Derived, R (Call::*)(MessageHandle),
714
+ EnableIfPromise<R>> {
715
+ public:
716
+ explicit InterceptClientToServerMessageHandler(
717
+ FilterCallData<Derived>* call_data, const CallArgs&)
718
+ : call_data_(call_data) {}
719
+
720
+ auto operator()() {
721
+ return [call_data = call_data_](MessageHandle msg) {
722
+ return Map(call_data->call.OnClientToServerMessage(std::move(msg)),
723
+ [call_data](ServerMetadataOrHandle<Message> md)
724
+ -> std::optional<MessageHandle> {
725
+ if (!md.ok()) {
726
+ call_data->error_latch.Set(std::move(md).TakeMetadata());
727
+ return std::nullopt;
728
+ }
729
+ return std::move(md).TakeValue();
730
+ });
731
+ };
732
+ }
733
+
734
+ private:
735
+ FilterCallData<Derived>* call_data_;
736
+ };
737
+
738
+ // For handling fused filters with a promise return type. This specialization is
739
+ // only for fused filters requiring a channel pointer.
740
+ template <typename Derived, typename Call, typename R>
741
+ class InterceptClientToServerMessageHandler<
742
+ Derived, R (Call::*)(MessageHandle, Derived*), EnableIfPromise<R>> {
743
+ public:
744
+ explicit InterceptClientToServerMessageHandler(
745
+ FilterCallData<Derived>* call_data, const CallArgs&)
746
+ : call_data_(call_data) {}
747
+
748
+ auto operator()() {
749
+ return [call_data = call_data_](MessageHandle msg) {
750
+ return Map(call_data->call.OnClientToServerMessage(std::move(msg),
751
+ call_data->channel),
752
+ [call_data](ServerMetadataOrHandle<Message> md)
753
+ -> std::optional<MessageHandle> {
754
+ if (!md.ok()) {
755
+ call_data->error_latch.Set(std::move(md).TakeMetadata());
756
+ return std::nullopt;
757
+ }
758
+ return std::move(md).TakeValue();
759
+ });
760
+ };
761
+ }
762
+
763
+ private:
764
+ FilterCallData<Derived>* call_data_;
765
+ };
766
+
767
+ template <typename HookFn, typename HalfCloseFn, typename Derived,
768
+ typename Ignored = void>
769
+ struct InterceptClientToServerMessage;
525
770
 
526
771
  template <typename Derived>
527
- inline void InterceptClientToServerMessage(const NoInterceptor*,
528
- const NoInterceptor*,
529
- FilterCallData<Derived>*,
530
- const CallArgs&) {}
772
+ struct InterceptClientToServerMessage<const NoInterceptor*,
773
+ const NoInterceptor*, Derived> {
774
+ static inline void Run(FilterCallData<Derived>*, const CallArgs&) {}
775
+ };
531
776
 
532
- template <typename CallArgs>
533
- inline void InterceptServerInitialMetadata(const NoInterceptor*, void*,
534
- const CallArgs&) {}
777
+ template <typename HookFn, typename Call, typename Derived>
778
+ struct InterceptClientToServerMessage<
779
+ HookFn, void (Call::*)(), Derived,
780
+ std::enable_if_t<!IsSameExcludingCVRef<HookFn, NoInterceptor*>, void>> {
781
+ static inline void Run(FilterCallData<Derived>* call_data,
782
+ const CallArgs& call_args) {
783
+ call_args.client_to_server_messages->InterceptAndMapWithHalfClose(
784
+ InterceptClientToServerMessageHandler<Derived, HookFn>(call_data,
785
+ call_args)(),
786
+ [call_data]() { call_data->call.OnClientToServerHalfClose(); });
787
+ }
788
+ };
789
+
790
+ template <typename HookFn, typename Derived>
791
+ struct InterceptClientToServerMessage<
792
+ HookFn, const NoInterceptor*, Derived,
793
+ std::enable_if_t<!IsSameExcludingCVRef<HookFn, NoInterceptor*>, void>> {
794
+ static inline void Run(FilterCallData<Derived>* call_data,
795
+ const CallArgs& call_args) {
796
+ call_args.client_to_server_messages->InterceptAndMap(
797
+ InterceptClientToServerMessageHandler<Derived, HookFn>(call_data,
798
+ call_args)());
799
+ }
800
+ };
801
+
802
+ template <typename Derived, typename MethodType, typename Ignored = void>
803
+ struct InterceptServerInitialMetadata;
535
804
 
536
805
  template <typename Derived>
537
- inline void InterceptServerInitialMetadata(
538
- void (Derived::Call::*fn)(ServerMetadata&),
539
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
540
- DCHECK(fn == &Derived::Call::OnServerInitialMetadata);
541
- call_args.server_initial_metadata->InterceptAndMap(
542
- [call_data](ServerMetadataHandle md) {
543
- call_data->call.OnServerInitialMetadata(*md);
544
- return md;
545
- });
546
- }
806
+ struct InterceptServerInitialMetadata<Derived, const NoInterceptor*> {
807
+ static inline void Run(FilterCallData<Derived>*, const CallArgs&) {}
808
+ };
547
809
 
548
810
  template <typename Derived>
549
- inline void InterceptServerInitialMetadata(
550
- absl::Status (Derived::Call::*fn)(ServerMetadata&),
551
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
552
- DCHECK(fn == &Derived::Call::OnServerInitialMetadata);
553
- call_args.server_initial_metadata->InterceptAndMap(
554
- [call_data](
555
- ServerMetadataHandle md) -> std::optional<ServerMetadataHandle> {
556
- auto status = call_data->call.OnServerInitialMetadata(*md);
557
- if (!status.ok() && !call_data->error_latch.is_set()) {
558
- call_data->error_latch.Set(ServerMetadataFromStatus(status));
559
- return std::nullopt;
560
- }
561
- return std::move(md);
562
- });
563
- }
811
+ struct InterceptServerInitialMetadata<Derived, void (Derived::Call::*)(
812
+ ServerMetadata&)> {
813
+ static inline void Run(FilterCallData<Derived>* call_data,
814
+ const CallArgs& call_args) {
815
+ call_args.server_initial_metadata->InterceptAndMap(
816
+ [call_data](ServerMetadataHandle md) {
817
+ call_data->call.OnServerInitialMetadata(*md);
818
+ return md;
819
+ });
820
+ }
821
+ };
564
822
 
565
823
  template <typename Derived>
566
- inline void InterceptServerInitialMetadata(
567
- void (Derived::Call::*fn)(ServerMetadata&, Derived*),
568
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
569
- DCHECK(fn == &Derived::Call::OnServerInitialMetadata);
570
- call_args.server_initial_metadata->InterceptAndMap(
571
- [call_data](ServerMetadataHandle md) {
572
- call_data->call.OnServerInitialMetadata(*md, call_data->channel);
573
- return md;
574
- });
575
- }
824
+ struct InterceptServerInitialMetadata<Derived, absl::Status (Derived::Call::*)(
825
+ ServerMetadata&)> {
826
+ static inline void Run(FilterCallData<Derived>* call_data,
827
+ const CallArgs& call_args) {
828
+ call_args.server_initial_metadata->InterceptAndMap(
829
+ [call_data](
830
+ ServerMetadataHandle md) -> std::optional<ServerMetadataHandle> {
831
+ auto status = call_data->call.OnServerInitialMetadata(*md);
832
+ if (!status.ok() && !call_data->error_latch.is_set()) {
833
+ call_data->error_latch.Set(ServerMetadataFromStatus(status));
834
+ return std::nullopt;
835
+ }
836
+ return std::move(md);
837
+ });
838
+ }
839
+ };
576
840
 
577
841
  template <typename Derived>
578
- inline void InterceptServerInitialMetadata(
579
- absl::Status (Derived::Call::*fn)(ServerMetadata&, Derived*),
580
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
581
- DCHECK(fn == &Derived::Call::OnServerInitialMetadata);
582
- call_args.server_initial_metadata->InterceptAndMap(
583
- [call_data](
584
- ServerMetadataHandle md) -> std::optional<ServerMetadataHandle> {
585
- auto status =
586
- call_data->call.OnServerInitialMetadata(*md, call_data->channel);
587
- if (!status.ok() && !call_data->error_latch.is_set()) {
588
- call_data->error_latch.Set(ServerMetadataFromStatus(status));
589
- return std::nullopt;
590
- }
591
- return std::move(md);
592
- });
593
- }
842
+ struct InterceptServerInitialMetadata<Derived, void (Derived::Call::*)(
843
+ ServerMetadata&, Derived*)> {
844
+ static inline void Run(FilterCallData<Derived>* call_data,
845
+ const CallArgs& call_args) {
846
+ call_args.server_initial_metadata->InterceptAndMap(
847
+ [call_data](ServerMetadataHandle md) {
848
+ call_data->call.OnServerInitialMetadata(*md, call_data->channel);
849
+ return md;
850
+ });
851
+ }
852
+ };
853
+
854
+ template <typename Derived>
855
+ struct InterceptServerInitialMetadata<Derived, absl::Status (Derived::Call::*)(
856
+ ServerMetadata&, Derived*)> {
857
+ static inline void Run(FilterCallData<Derived>* call_data,
858
+ const CallArgs& call_args) {
859
+ call_args.server_initial_metadata->InterceptAndMap(
860
+ [call_data](
861
+ ServerMetadataHandle md) -> std::optional<ServerMetadataHandle> {
862
+ auto status =
863
+ call_data->call.OnServerInitialMetadata(*md, call_data->channel);
864
+ if (!status.ok() && !call_data->error_latch.is_set()) {
865
+ call_data->error_latch.Set(ServerMetadataFromStatus(status));
866
+ return std::nullopt;
867
+ }
868
+ return std::move(md);
869
+ });
870
+ }
871
+ };
872
+
873
+ // For handling fused filters with a promise return type. This specialization is
874
+ // only for fused filters requiring a channel pointer.
875
+ template <typename Derived, typename Call, typename R>
876
+ struct InterceptServerInitialMetadata<
877
+ Derived, R (Call::*)(ServerMetadataHandle, Derived*), EnableIfPromise<R>> {
878
+ static inline void Run(FilterCallData<Derived>* call_data,
879
+ const CallArgs& call_args) {
880
+ call_args.server_initial_metadata->InterceptAndMap(
881
+ [call_data](ServerMetadataHandle md) {
882
+ return Map(
883
+ call_data->call.OnServerInitialMetadata(std::move(md),
884
+ call_data->channel),
885
+ [call_data](ServerMetadataOrHandle<ServerMetadata> md)
886
+ -> std::optional<ServerMetadataHandle> {
887
+ if (!md.ok()) {
888
+ call_data->error_latch.Set(std::move(md).TakeMetadata());
889
+ return std::nullopt;
890
+ }
891
+ return std::move(md).TakeValue();
892
+ });
893
+ });
894
+ }
895
+ };
896
+
897
+ // For handling fused filters with a promise return type. This specialization is
898
+ // only for fused filters not requiring a channel pointer.
899
+ template <typename Derived, typename Call, typename R>
900
+ struct InterceptServerInitialMetadata<
901
+ Derived, R (Call::*)(ServerMetadataHandle), EnableIfPromise<R>> {
902
+ static inline void Run(FilterCallData<Derived>* call_data,
903
+ const CallArgs& call_args) {
904
+ call_args.server_initial_metadata->InterceptAndMap(
905
+ [call_data](ServerMetadataHandle md) {
906
+ return Map(
907
+ call_data->call.OnServerInitialMetadata(std::move(md)),
908
+ [call_data](ServerMetadataOrHandle<ServerMetadata> md)
909
+ -> std::optional<ServerMetadataHandle> {
910
+ if (!md.ok()) {
911
+ call_data->error_latch.Set(std::move(md).TakeMetadata());
912
+ return std::nullopt;
913
+ }
914
+ return std::move(md).TakeValue();
915
+ });
916
+ });
917
+ }
918
+ };
594
919
 
595
- inline void InterceptServerToClientMessage(const NoInterceptor*, void*,
596
- const CallArgs&) {}
920
+ template <typename Derived, typename MethodType, typename Ignored = void>
921
+ struct InterceptServerToClientMessage;
597
922
 
598
923
  template <typename Derived>
599
- inline void InterceptServerToClientMessage(
600
- void (Derived::Call::*fn)(const Message&),
601
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
602
- DCHECK(fn == &Derived::Call::OnServerToClientMessage);
603
- call_args.server_to_client_messages->InterceptAndMap(
604
- [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
605
- call_data->call.OnServerToClientMessage(*msg);
606
- return std::move(msg);
607
- });
608
- }
924
+ struct InterceptServerToClientMessage<Derived, const NoInterceptor*> {
925
+ static inline void Run(FilterCallData<Derived>*, const CallArgs&) {}
926
+ };
609
927
 
610
928
  template <typename Derived>
611
- inline void InterceptServerToClientMessage(
612
- ServerMetadataHandle (Derived::Call::*fn)(const Message&),
613
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
614
- DCHECK(fn == &Derived::Call::OnServerToClientMessage);
615
- call_args.server_to_client_messages->InterceptAndMap(
616
- [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
617
- auto return_md = call_data->call.OnServerToClientMessage(*msg);
618
- if (return_md == nullptr) return std::move(msg);
619
- if (call_data->error_latch.is_set()) return std::nullopt;
620
- call_data->error_latch.Set(std::move(return_md));
621
- return std::nullopt;
622
- });
623
- }
929
+ struct InterceptServerToClientMessage<Derived,
930
+ void (Derived::Call::*)(const Message&)> {
931
+ static inline void Run(FilterCallData<Derived>* call_data,
932
+ const CallArgs& call_args) {
933
+ call_args.server_to_client_messages->InterceptAndMap(
934
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
935
+ call_data->call.OnServerToClientMessage(*msg);
936
+ return std::move(msg);
937
+ });
938
+ }
939
+ };
624
940
 
625
941
  template <typename Derived>
626
- inline void InterceptServerToClientMessage(
627
- void (Derived::Call::*fn)(const Message&, Derived*),
628
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
629
- DCHECK(fn == &Derived::Call::OnServerToClientMessage);
630
- call_args.server_to_client_messages->InterceptAndMap(
631
- [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
632
- call_data->call.OnServerToClientMessage(*msg, call_data->channel);
633
- return std::move(msg);
634
- });
635
- }
942
+ struct InterceptServerToClientMessage<Derived,
943
+ void (Derived::Call::*)(Message&)> {
944
+ static inline void Run(FilterCallData<Derived>* call_data,
945
+ const CallArgs& call_args) {
946
+ call_args.server_to_client_messages->InterceptAndMap(
947
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
948
+ call_data->call.OnServerToClientMessage(*msg);
949
+ return std::move(msg);
950
+ });
951
+ }
952
+ };
636
953
 
637
954
  template <typename Derived>
638
- inline void InterceptServerToClientMessage(
639
- ServerMetadataHandle (Derived::Call::*fn)(const Message&, Derived*),
640
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
641
- DCHECK(fn == &Derived::Call::OnServerToClientMessage);
642
- call_args.server_to_client_messages->InterceptAndMap(
643
- [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
644
- auto return_md =
645
- call_data->call.OnServerToClientMessage(*msg, call_data->channel);
646
- if (return_md == nullptr) return std::move(msg);
647
- if (call_data->error_latch.is_set()) return std::nullopt;
648
- call_data->error_latch.Set(std::move(return_md));
649
- return std::nullopt;
650
- });
651
- }
955
+ struct InterceptServerToClientMessage<
956
+ Derived, ServerMetadataHandle (Derived::Call::*)(const Message&)> {
957
+ static inline void Run(FilterCallData<Derived>* call_data,
958
+ const CallArgs& call_args) {
959
+ call_args.server_to_client_messages->InterceptAndMap(
960
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
961
+ auto return_md = call_data->call.OnServerToClientMessage(*msg);
962
+ if (return_md == nullptr) return std::move(msg);
963
+ if (call_data->error_latch.is_set()) return std::nullopt;
964
+ call_data->error_latch.Set(std::move(return_md));
965
+ return std::nullopt;
966
+ });
967
+ }
968
+ };
652
969
 
653
970
  template <typename Derived>
654
- inline void InterceptServerToClientMessage(
655
- MessageHandle (Derived::Call::*fn)(MessageHandle, Derived*),
656
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
657
- DCHECK(fn == &Derived::Call::OnServerToClientMessage);
658
- call_args.server_to_client_messages->InterceptAndMap(
659
- [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
660
- return call_data->call.OnServerToClientMessage(std::move(msg),
661
- call_data->channel);
662
- });
663
- }
971
+ struct InterceptServerToClientMessage<Derived, void (Derived::Call::*)(
972
+ const Message&, Derived*)> {
973
+ static inline void Run(FilterCallData<Derived>* call_data,
974
+ const CallArgs& call_args) {
975
+ call_args.server_to_client_messages->InterceptAndMap(
976
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
977
+ call_data->call.OnServerToClientMessage(*msg, call_data->channel);
978
+ return std::move(msg);
979
+ });
980
+ }
981
+ };
664
982
 
665
983
  template <typename Derived>
666
- inline void InterceptServerToClientMessage(
667
- absl::StatusOr<MessageHandle> (Derived::Call::*fn)(MessageHandle, Derived*),
668
- FilterCallData<Derived>* call_data, const CallArgs& call_args) {
669
- DCHECK(fn == &Derived::Call::OnServerToClientMessage);
670
- call_args.server_to_client_messages->InterceptAndMap(
671
- [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
672
- auto r = call_data->call.OnServerToClientMessage(std::move(msg),
984
+ struct InterceptServerToClientMessage<Derived,
985
+ ServerMetadataHandle (Derived::Call::*)(
986
+ const Message&, Derived*)> {
987
+ static inline void Run(FilterCallData<Derived>* call_data,
988
+ const CallArgs& call_args) {
989
+ call_args.server_to_client_messages->InterceptAndMap(
990
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
991
+ auto return_md =
992
+ call_data->call.OnServerToClientMessage(*msg, call_data->channel);
993
+ if (return_md == nullptr) return std::move(msg);
994
+ if (call_data->error_latch.is_set()) return std::nullopt;
995
+ call_data->error_latch.Set(std::move(return_md));
996
+ return std::nullopt;
997
+ });
998
+ }
999
+ };
1000
+
1001
+ template <typename Derived>
1002
+ struct InterceptServerToClientMessage<Derived, MessageHandle (Derived::Call::*)(
1003
+ MessageHandle, Derived*)> {
1004
+ static inline void Run(FilterCallData<Derived>* call_data,
1005
+ const CallArgs& call_args) {
1006
+ call_args.server_to_client_messages->InterceptAndMap(
1007
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
1008
+ return call_data->call.OnServerToClientMessage(std::move(msg),
673
1009
  call_data->channel);
674
- if (r.ok()) return std::move(*r);
675
- if (call_data->error_latch.is_set()) return std::nullopt;
676
- call_data->error_latch.Set(ServerMetadataFromStatus(r.status()));
677
- return std::nullopt;
678
- });
679
- }
1010
+ });
1011
+ }
1012
+ };
680
1013
 
681
- inline void InterceptFinalize(const NoInterceptor*, void*, void*) {}
1014
+ template <typename Derived>
1015
+ struct InterceptServerToClientMessage<Derived, absl::StatusOr<MessageHandle> (
1016
+ Derived::Call::*)(
1017
+ MessageHandle, Derived*)> {
1018
+ static inline void Run(FilterCallData<Derived>* call_data,
1019
+ const CallArgs& call_args) {
1020
+ call_args.server_to_client_messages->InterceptAndMap(
1021
+ [call_data](MessageHandle msg) -> std::optional<MessageHandle> {
1022
+ auto r = call_data->call.OnServerToClientMessage(std::move(msg),
1023
+ call_data->channel);
1024
+ if (r.ok()) return std::move(*r);
1025
+ if (call_data->error_latch.is_set()) return std::nullopt;
1026
+ call_data->error_latch.Set(ServerMetadataFromStatus(r.status()));
1027
+ return std::nullopt;
1028
+ });
1029
+ }
1030
+ };
682
1031
 
683
- template <class Call>
684
- inline void InterceptFinalize(void (Call::*fn)(const grpc_call_final_info*),
685
- void*, Call* call) {
686
- DCHECK(fn == &Call::OnFinalize);
687
- GetContext<CallFinalization>()->Add(
688
- [call](const grpc_call_final_info* final_info) {
689
- call->OnFinalize(final_info);
690
- });
691
- }
1032
+ // For handling fused filters with a promise return type. This specialization is
1033
+ // only for fused filters not requiring a channel pointer.
1034
+ template <typename Derived, typename Call, typename R>
1035
+ struct InterceptServerToClientMessage<Derived, R (Call::*)(MessageHandle),
1036
+ EnableIfPromise<R>> {
1037
+ static inline void Run(FilterCallData<Derived>* call_data,
1038
+ const CallArgs& call_args) {
1039
+ call_args.server_to_client_messages->InterceptAndMap(
1040
+ [call_data](MessageHandle msg) {
1041
+ return Map(
1042
+ call_data->call.OnServerToClientMessage(std::move(msg)),
1043
+ [call_data](ServerMetadataOrHandle<Message> msg)
1044
+ -> std::optional<MessageHandle> {
1045
+ if (!msg.ok()) {
1046
+ call_data->error_latch.Set(std::move(msg).TakeMetadata());
1047
+ return std::nullopt;
1048
+ }
1049
+ return std::move(msg).TakeValue();
1050
+ });
1051
+ });
1052
+ }
1053
+ };
692
1054
 
693
- template <class Derived>
694
- inline void InterceptFinalize(
695
- void (Derived::Call::*fn)(const grpc_call_final_info*, Derived*),
696
- Derived* channel, typename Derived::Call* call) {
697
- DCHECK(fn == &Derived::Call::OnFinalize);
698
- GetContext<CallFinalization>()->Add(
699
- [call, channel](const grpc_call_final_info* final_info) {
700
- call->OnFinalize(final_info, channel);
701
- });
702
- }
1055
+ // For handling fused filters with a promise return type. This specialization is
1056
+ // only for fused filters requiring a channel pointer.
1057
+ template <typename Derived, typename Call, typename R>
1058
+ struct InterceptServerToClientMessage<
1059
+ Derived, R (Call::*)(MessageHandle, Derived*), EnableIfPromise<R>> {
1060
+ static inline void Run(FilterCallData<Derived>* call_data,
1061
+ const CallArgs& call_args) {
1062
+ call_args.server_to_client_messages->InterceptAndMap(
1063
+ [call_data](MessageHandle msg) {
1064
+ return Map(
1065
+ call_data->call.OnServerToClientMessage(std::move(msg),
1066
+ call_data->channel),
1067
+ [call_data](ServerMetadataOrHandle<Message> msg)
1068
+ -> std::optional<MessageHandle> {
1069
+ if (!msg.ok()) {
1070
+ call_data->error_latch.Set(std::move(msg).TakeMetadata());
1071
+ return std::nullopt;
1072
+ }
1073
+ return std::move(msg).TakeValue();
1074
+ });
1075
+ });
1076
+ }
1077
+ };
1078
+
1079
+ template <typename Derived, typename MethodType, typename Ignored = void>
1080
+ struct InterceptFinalize;
1081
+
1082
+ template <typename Derived>
1083
+ struct InterceptFinalize<Derived, const NoInterceptor*> {
1084
+ static inline void Run(void*, void*) {}
1085
+ };
1086
+
1087
+ template <typename Derived, typename Call>
1088
+ struct InterceptFinalize<Derived, void (Call::*)(const grpc_call_final_info*)> {
1089
+ static inline void Run(void*, Call* call) {
1090
+ GetContext<CallFinalization>()->Add(
1091
+ [call](const grpc_call_final_info* final_info) {
1092
+ call->OnFinalize(final_info);
1093
+ });
1094
+ }
1095
+ };
1096
+
1097
+ template <class Derived, typename Call>
1098
+ struct InterceptFinalize<Derived, void (Call::*)(const grpc_call_final_info*,
1099
+ Derived*)> {
1100
+ static inline void Run(Derived* channel, Call* call) {
1101
+ GetContext<CallFinalization>()->Add(
1102
+ [call, channel](const grpc_call_final_info* final_info) {
1103
+ call->OnFinalize(final_info, channel);
1104
+ });
1105
+ }
1106
+ };
703
1107
 
704
1108
  template <typename Derived>
705
1109
  absl::enable_if_t<std::is_empty<FilterCallData<Derived>>::value,
@@ -786,20 +1190,27 @@ class ImplementChannelFilter : public ChannelFilter,
786
1190
  CallArgs call_args, NextPromiseFactory next_promise_factory) final {
787
1191
  auto* call = promise_filter_detail::MakeFilterCall<Derived>(
788
1192
  static_cast<Derived*>(this));
789
- promise_filter_detail::InterceptClientToServerMessage(
790
- &Derived::Call::OnClientToServerMessage,
791
- &Derived::Call::OnClientToServerHalfClose, call, call_args);
792
- promise_filter_detail::InterceptServerInitialMetadata(
793
- &Derived::Call::OnServerInitialMetadata, call, call_args);
794
- promise_filter_detail::InterceptServerToClientMessage(
795
- &Derived::Call::OnServerToClientMessage, call, call_args);
796
- promise_filter_detail::InterceptFinalize(
797
- &Derived::Call::OnFinalize, static_cast<Derived*>(this),
798
- static_cast<typename Derived::Call*>(&call->call));
1193
+ promise_filter_detail::InterceptClientToServerMessage<
1194
+ decltype(&Derived::Call::OnClientToServerMessage),
1195
+ decltype(&Derived::Call::OnClientToServerHalfClose),
1196
+ Derived>::Run(call, call_args);
1197
+ promise_filter_detail::InterceptServerInitialMetadata<
1198
+ Derived,
1199
+ decltype(&Derived::Call::OnServerInitialMetadata)>::Run(call,
1200
+ call_args);
1201
+ promise_filter_detail::InterceptServerToClientMessage<
1202
+ Derived,
1203
+ decltype(&Derived::Call::OnServerToClientMessage)>::Run(call,
1204
+ call_args);
1205
+ promise_filter_detail::
1206
+ InterceptFinalize<Derived, decltype(&Derived::Call::OnFinalize)>::Run(
1207
+ static_cast<Derived*>(this),
1208
+ static_cast<typename Derived::Call*>(&call->call));
799
1209
  return promise_filter_detail::MapResult(
800
1210
  &Derived::Call::OnServerTrailingMetadata,
801
1211
  promise_filter_detail::RaceAsyncCompletion<
802
- promise_filter_detail::CallHasAsyncErrorInterceptor<Derived>()>::
1212
+ promise_filter_detail::CallHasAsyncErrorInterceptor<
1213
+ Derived>::value>::
803
1214
  Run(promise_filter_detail::RunCall(
804
1215
  &Derived::Call::OnClientInitialMetadata,
805
1216
  std::move(call_args), std::move(next_promise_factory),
@@ -837,7 +1248,9 @@ class InvalidChannelFilter : public ChannelFilter {
837
1248
  };
838
1249
 
839
1250
  // Call data shared between all implementations of promise-based filters.
840
- class BaseCallData : public Activity, private Wakeable {
1251
+ class BaseCallData : public Activity,
1252
+ private Wakeable,
1253
+ public channelz::DataSource {
841
1254
  protected:
842
1255
  // Hook to allow interception of messages on the send/receive path by
843
1256
  // PipeSender and PipeReceiver, as appropriate according to whether we're
@@ -862,7 +1275,8 @@ class BaseCallData : public Activity, private Wakeable {
862
1275
  ~BaseCallData() override;
863
1276
 
864
1277
  void set_pollent(grpc_polling_entity* pollent) {
865
- CHECK(nullptr == pollent_.exchange(pollent, std::memory_order_release));
1278
+ GRPC_CHECK(nullptr ==
1279
+ pollent_.exchange(pollent, std::memory_order_release));
866
1280
  }
867
1281
 
868
1282
  // Activity implementation (partial).
@@ -881,6 +1295,8 @@ class BaseCallData : public Activity, private Wakeable {
881
1295
 
882
1296
  Call* call() { return arena_->GetContext<Call>(); }
883
1297
 
1298
+ void AddData(channelz::DataSink sink) final;
1299
+
884
1300
  protected:
885
1301
  class ScopedContext : public promise_detail::Context<Arena>,
886
1302
  public promise_detail::Context<grpc_polling_entity>,
@@ -896,16 +1312,14 @@ class BaseCallData : public Activity, private Wakeable {
896
1312
  }
897
1313
  };
898
1314
 
899
- class Flusher : public latent_see::InnerScope {
1315
+ class Flusher {
900
1316
  public:
901
- explicit Flusher(BaseCallData* call,
902
- latent_see::Metadata* desc = GRPC_LATENT_SEE_METADATA(
903
- "PromiseBasedFilter::Flusher"));
1317
+ explicit Flusher(BaseCallData* call);
904
1318
  // Calls closures, schedules batches, relinquishes call combiner.
905
1319
  ~Flusher();
906
1320
 
907
1321
  void Resume(grpc_transport_stream_op_batch* batch) {
908
- CHECK(!call_->is_last());
1322
+ GRPC_CHECK(!call_->is_last());
909
1323
  if (batch->HasOp()) {
910
1324
  release_.push_back(batch);
911
1325
  } else if (batch->on_complete != nullptr) {
@@ -984,7 +1398,7 @@ class BaseCallData : public Activity, private Wakeable {
984
1398
  PipeSender<MessageHandle>* original_sender() override { abort(); }
985
1399
 
986
1400
  void GotPipe(PipeReceiver<MessageHandle>* receiver) override {
987
- CHECK_EQ(receiver_, nullptr);
1401
+ GRPC_CHECK_EQ(receiver_, nullptr);
988
1402
  receiver_ = receiver;
989
1403
  }
990
1404
 
@@ -992,7 +1406,7 @@ class BaseCallData : public Activity, private Wakeable {
992
1406
 
993
1407
  PipeSender<MessageHandle>* Push() override { return &pipe_.sender; }
994
1408
  PipeReceiver<MessageHandle>* Pull() override {
995
- CHECK_NE(receiver_, nullptr);
1409
+ GRPC_CHECK_NE(receiver_, nullptr);
996
1410
  return receiver_;
997
1411
  }
998
1412
 
@@ -1013,12 +1427,12 @@ class BaseCallData : public Activity, private Wakeable {
1013
1427
  void GotPipe(PipeReceiver<MessageHandle>*) override { abort(); }
1014
1428
 
1015
1429
  void GotPipe(PipeSender<MessageHandle>* sender) override {
1016
- CHECK_EQ(sender_, nullptr);
1430
+ GRPC_CHECK_EQ(sender_, nullptr);
1017
1431
  sender_ = sender;
1018
1432
  }
1019
1433
 
1020
1434
  PipeSender<MessageHandle>* Push() override {
1021
- CHECK_NE(sender_, nullptr);
1435
+ GRPC_CHECK_NE(sender_, nullptr);
1022
1436
  return sender_;
1023
1437
  }
1024
1438
  PipeReceiver<MessageHandle>* Pull() override { return &pipe_.receiver; }
@@ -1061,6 +1475,10 @@ class BaseCallData : public Activity, private Wakeable {
1061
1475
  // Return true if we've released the message for forwarding down the stack.
1062
1476
  bool IsForwarded() const { return state_ == State::kForwardedBatch; }
1063
1477
 
1478
+ channelz::PropertyList ChannelzProperties() {
1479
+ return channelz::PropertyList().Set("state", StateString(state_));
1480
+ }
1481
+
1064
1482
  private:
1065
1483
  enum class State : uint8_t {
1066
1484
  // Starting state: no batch started, no outgoing pipe configured.
@@ -1134,6 +1552,10 @@ class BaseCallData : public Activity, private Wakeable {
1134
1552
  // Call is completed, we have trailing metadata. Close things out.
1135
1553
  void Done(const ServerMetadata& metadata, Flusher* flusher);
1136
1554
 
1555
+ channelz::PropertyList ChannelzProperties() {
1556
+ return channelz::PropertyList().Set("state", StateString(state_));
1557
+ }
1558
+
1137
1559
  private:
1138
1560
  enum class State : uint8_t {
1139
1561
  // Starting state: no batch started, no incoming pipe configured.
@@ -1216,6 +1638,7 @@ class BaseCallData : public Activity, private Wakeable {
1216
1638
  }
1217
1639
  SendMessage* send_message() const { return send_message_; }
1218
1640
  ReceiveMessage* receive_message() const { return receive_message_; }
1641
+ virtual channelz::PropertyList ChannelzProperties() const;
1219
1642
 
1220
1643
  bool is_last() const {
1221
1644
  return grpc_call_stack_element(call_stack_, call_stack_->count - 1) ==
@@ -1297,6 +1720,7 @@ class ClientCallData : public BaseCallData {
1297
1720
  static const char* StateString(SendInitialState);
1298
1721
  static const char* StateString(RecvTrailingState);
1299
1722
  std::string DebugString() const;
1723
+ channelz::PropertyList ChannelzProperties() const override;
1300
1724
 
1301
1725
  struct RecvInitialMetadata;
1302
1726
  class PollContext;
@@ -1413,6 +1837,7 @@ class ServerCallData : public BaseCallData {
1413
1837
  static const char* StateString(RecvInitialState state);
1414
1838
  static const char* StateString(SendTrailingState state);
1415
1839
  std::string DebugString() const;
1840
+ channelz::PropertyList ChannelzProperties() const override;
1416
1841
 
1417
1842
  class PollContext;
1418
1843
  struct SendInitialMetadata;
@@ -1533,7 +1958,7 @@ struct CallDataFilterWithFlagsMethods {
1533
1958
  if ((kFlags & kFilterIsLast) != 0) {
1534
1959
  ExecCtx::Run(DEBUG_LOCATION, then_schedule_closure, absl::OkStatus());
1535
1960
  } else {
1536
- CHECK_EQ(then_schedule_closure, nullptr);
1961
+ GRPC_CHECK_EQ(then_schedule_closure, nullptr);
1537
1962
  }
1538
1963
  }
1539
1964
  };
@@ -1570,12 +1995,12 @@ template <typename F, uint8_t kFlags>
1570
1995
  struct ChannelFilterWithFlagsMethods {
1571
1996
  static absl::Status InitChannelElem(grpc_channel_element* elem,
1572
1997
  grpc_channel_element_args* args) {
1573
- CHECK(args->is_last == ((kFlags & kFilterIsLast) != 0));
1574
- auto status = F::Create(
1575
- args->channel_args,
1576
- ChannelFilter::Args(args->channel_stack, elem,
1577
- grpc_channel_stack_filter_instance_number,
1578
- args->old_blackboard, args->new_blackboard));
1998
+ GRPC_CHECK(args->is_last == ((kFlags & kFilterIsLast) != 0));
1999
+ auto status =
2000
+ F::Create(args->channel_args,
2001
+ ChannelFilter::Args(args->channel_stack, elem,
2002
+ grpc_channel_stack_filter_instance_number,
2003
+ args->config, args->blackboard));
1579
2004
  if (!status.ok()) {
1580
2005
  new (elem->channel_data) F*(nullptr);
1581
2006
  return absl_status_to_grpc_error(status.status());