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
@@ -30,19 +30,19 @@
30
30
 
31
31
  #include <algorithm>
32
32
  #include <atomic>
33
+ #include <cstddef>
33
34
  #include <memory>
34
35
  #include <optional>
36
+ #include <regex>
35
37
  #include <utility>
38
+ #include <vector>
36
39
 
37
- #include "absl/base/thread_annotations.h"
38
- #include "absl/log/check.h"
39
- #include "absl/log/log.h"
40
- #include "absl/status/status.h"
41
- #include "absl/strings/string_view.h"
42
40
  #include "src/core/lib/debug/trace.h"
41
+ #include "src/core/lib/experiments/experiments.h"
43
42
  #include "src/core/lib/iomgr/closure.h"
44
43
  #include "src/core/lib/iomgr/endpoint.h"
45
44
  #include "src/core/lib/iomgr/error.h"
45
+ #include "src/core/lib/iomgr/event_engine_shims/endpoint.h"
46
46
  #include "src/core/lib/iomgr/exec_ctx.h"
47
47
  #include "src/core/lib/iomgr/iomgr_fwd.h"
48
48
  #include "src/core/lib/resource_quota/api.h"
@@ -53,216 +53,166 @@
53
53
  #include "src/core/tsi/transport_security_grpc.h"
54
54
  #include "src/core/tsi/transport_security_interface.h"
55
55
  #include "src/core/util/debug_location.h"
56
+ #include "src/core/util/grpc_check.h"
56
57
  #include "src/core/util/orphanable.h"
57
58
  #include "src/core/util/ref_counted_ptr.h"
58
59
  #include "src/core/util/string.h"
59
60
  #include "src/core/util/sync.h"
61
+ #include "absl/base/thread_annotations.h"
62
+ #include "absl/log/log.h"
63
+ #include "absl/status/status.h"
64
+ #include "absl/strings/string_view.h"
65
+ #include "absl/types/span.h"
60
66
 
61
67
  #define STAGING_BUFFER_SIZE 8192
62
68
 
63
69
  static void on_read(void* user_data, grpc_error_handle error);
64
70
  static void on_write(void* user_data, grpc_error_handle error);
65
71
 
72
+ namespace grpc_core {
66
73
  namespace {
67
- struct secure_endpoint : public grpc_endpoint {
68
- secure_endpoint(const grpc_endpoint_vtable* vtbl,
69
- tsi_frame_protector* protector,
70
- tsi_zero_copy_grpc_protector* zero_copy_protector,
71
- grpc_core::OrphanablePtr<grpc_endpoint> endpoint,
72
- grpc_slice* leftover_slices,
73
- const grpc_channel_args* channel_args,
74
- size_t leftover_nslices)
75
- : wrapped_ep(std::move(endpoint)),
76
- protector(protector),
77
- zero_copy_protector(zero_copy_protector) {
78
- this->vtable = vtbl;
79
- gpr_mu_init(&protector_mu);
80
- GRPC_CLOSURE_INIT(&on_read, ::on_read, this, grpc_schedule_on_exec_ctx);
81
- GRPC_CLOSURE_INIT(&on_write, ::on_write, this, grpc_schedule_on_exec_ctx);
82
- grpc_slice_buffer_init(&source_buffer);
83
- grpc_slice_buffer_init(&leftover_bytes);
84
- for (size_t i = 0; i < leftover_nslices; i++) {
85
- grpc_slice_buffer_add(&leftover_bytes,
86
- grpc_core::CSliceRef(leftover_slices[i]));
74
+
75
+ grpc_slice AllocSlice(size_t size, void* user_data) {
76
+ auto* owner = static_cast<MemoryOwner*>(user_data);
77
+ return owner->MakeSlice(MemoryRequest(size));
78
+ }
79
+
80
+ class FrameProtector : public RefCounted<FrameProtector> {
81
+ public:
82
+ FrameProtector(tsi_frame_protector* protector,
83
+ tsi_zero_copy_grpc_protector* zero_copy_protector,
84
+ grpc_slice* leftover_slices, size_t leftover_nslices,
85
+ const ChannelArgs& args)
86
+ : protector_(protector),
87
+ zero_copy_protector_(zero_copy_protector),
88
+ memory_owner_(args.GetObject<ResourceQuota>()
89
+ ->memory_quota()
90
+ ->CreateMemoryOwner()),
91
+ self_reservation_(memory_owner_.MakeReservation(sizeof(*this))) {
92
+ GRPC_TRACE_LOG(secure_endpoint, INFO)
93
+ << "FrameProtector: " << this << " protector: " << protector_
94
+ << " zero_copy_protector: " << zero_copy_protector_
95
+ << " leftover_nslices: " << leftover_nslices;
96
+ if (leftover_nslices > 0) {
97
+ leftover_bytes_ = std::make_unique<SliceBuffer>();
98
+ for (size_t i = 0; i < leftover_nslices; i++) {
99
+ leftover_bytes_->Append(Slice(CSliceRef(leftover_slices[i])));
100
+ }
87
101
  }
88
- grpc_slice_buffer_init(&output_buffer);
89
- memory_owner = grpc_core::ResourceQuotaFromChannelArgs(channel_args)
90
- ->memory_quota()
91
- ->CreateMemoryOwner();
92
- self_reservation = memory_owner.MakeReservation(sizeof(*this));
93
- if (zero_copy_protector) {
94
- read_staging_buffer = grpc_empty_slice();
95
- write_staging_buffer = grpc_empty_slice();
102
+ if (zero_copy_protector_ != nullptr) {
103
+ if (IsTrackZeroCopyAllocationsInResourceQuotaEnabled()) {
104
+ tsi_zero_copy_grpc_protector_set_allocator(zero_copy_protector_,
105
+ &AllocSlice, &memory_owner_);
106
+ }
107
+ read_staging_buffer_ = grpc_empty_slice();
108
+ write_staging_buffer_ = grpc_empty_slice();
96
109
  } else {
97
- read_staging_buffer =
98
- memory_owner.MakeSlice(grpc_core::MemoryRequest(STAGING_BUFFER_SIZE));
99
- write_staging_buffer =
100
- memory_owner.MakeSlice(grpc_core::MemoryRequest(STAGING_BUFFER_SIZE));
110
+ read_staging_buffer_ =
111
+ memory_owner_.MakeSlice(MemoryRequest(STAGING_BUFFER_SIZE));
112
+ write_staging_buffer_ =
113
+ memory_owner_.MakeSlice(MemoryRequest(STAGING_BUFFER_SIZE));
101
114
  }
102
- has_posted_reclaimer.store(false, std::memory_order_relaxed);
103
- min_progress_size = 1;
104
- grpc_slice_buffer_init(&protector_staging_buffer);
105
- gpr_ref_init(&ref, 1);
115
+ is_zero_copy_protector_ = (zero_copy_protector_ != nullptr);
106
116
  }
107
117
 
108
- ~secure_endpoint() {
109
- tsi_frame_protector_destroy(protector);
110
- tsi_zero_copy_grpc_protector_destroy(zero_copy_protector);
111
- grpc_slice_buffer_destroy(&source_buffer);
112
- grpc_slice_buffer_destroy(&leftover_bytes);
113
- grpc_core::CSliceUnref(read_staging_buffer);
114
- grpc_core::CSliceUnref(write_staging_buffer);
115
- grpc_slice_buffer_destroy(&output_buffer);
116
- grpc_slice_buffer_destroy(&protector_staging_buffer);
117
- gpr_mu_destroy(&protector_mu);
118
+ ~FrameProtector() override {
119
+ tsi_frame_protector_destroy(protector_);
120
+ tsi_zero_copy_grpc_protector_destroy(zero_copy_protector_);
121
+ CSliceUnref(read_staging_buffer_);
122
+ CSliceUnref(write_staging_buffer_);
118
123
  }
119
124
 
120
- grpc_core::OrphanablePtr<grpc_endpoint> wrapped_ep;
121
- struct tsi_frame_protector* protector;
122
- struct tsi_zero_copy_grpc_protector* zero_copy_protector;
123
- gpr_mu protector_mu;
124
- grpc_core::Mutex read_mu;
125
- grpc_core::Mutex write_mu;
126
- // saved upper level callbacks and user_data.
127
- grpc_closure* read_cb = nullptr;
128
- grpc_closure* write_cb = nullptr;
129
- grpc_closure on_read;
130
- grpc_closure on_write;
131
- grpc_slice_buffer* read_buffer = nullptr;
132
- grpc_slice_buffer source_buffer;
133
- // saved handshaker leftover data to unprotect.
134
- grpc_slice_buffer leftover_bytes;
135
- // buffers for read and write
136
- grpc_slice read_staging_buffer ABSL_GUARDED_BY(read_mu);
137
- grpc_slice write_staging_buffer ABSL_GUARDED_BY(write_mu);
138
- grpc_slice_buffer output_buffer;
139
- grpc_core::MemoryOwner memory_owner;
140
- grpc_core::MemoryAllocator::Reservation self_reservation;
141
- std::atomic<bool> has_posted_reclaimer;
142
- int min_progress_size;
143
- grpc_slice_buffer protector_staging_buffer;
144
- gpr_refcount ref;
145
- };
146
- } // namespace
147
-
148
- static void destroy(secure_endpoint* ep) { delete ep; }
125
+ Mutex* read_mu() ABSL_LOCK_RETURNED(read_mu_) { return &read_mu_; }
126
+ Mutex* write_mu() ABSL_LOCK_RETURNED(write_mu_) { return &write_mu_; }
149
127
 
150
- #ifndef NDEBUG
151
- #define SECURE_ENDPOINT_UNREF(ep, reason) \
152
- secure_endpoint_unref((ep), (reason), __FILE__, __LINE__)
153
- #define SECURE_ENDPOINT_REF(ep, reason) \
154
- secure_endpoint_ref((ep), (reason), __FILE__, __LINE__)
155
- static void secure_endpoint_unref(secure_endpoint* ep, const char* reason,
156
- const char* file, int line) {
157
- if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint)) {
158
- gpr_atm val = gpr_atm_no_barrier_load(&ep->ref.count);
159
- VLOG(2).AtLocation(file, line) << "SECENDP unref " << ep << " : " << reason
160
- << " " << val << " -> " << val - 1;
161
- }
162
- if (gpr_unref(&ep->ref)) {
163
- destroy(ep);
164
- }
165
- }
166
-
167
- static void secure_endpoint_ref(secure_endpoint* ep, const char* reason,
168
- const char* file, int line) {
169
- if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint)) {
170
- gpr_atm val = gpr_atm_no_barrier_load(&ep->ref.count);
171
- VLOG(2).AtLocation(file, line) << "SECENDP ref " << ep << " : " << reason
172
- << " " << val << " -> " << val + 1;
173
- }
174
- gpr_ref(&ep->ref);
175
- }
176
- #else
177
- #define SECURE_ENDPOINT_UNREF(ep, reason) secure_endpoint_unref((ep))
178
- #define SECURE_ENDPOINT_REF(ep, reason) secure_endpoint_ref((ep))
179
- static void secure_endpoint_unref(secure_endpoint* ep) {
180
- if (gpr_unref(&ep->ref)) {
181
- destroy(ep);
128
+ void TraceOp(absl::string_view op, grpc_slice_buffer* slices) {
129
+ if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint)) {
130
+ size_t i;
131
+ if (slices->length < 64) {
132
+ for (i = 0; i < slices->count; i++) {
133
+ char* data =
134
+ grpc_dump_slice(slices->slices[i], GPR_DUMP_HEX | GPR_DUMP_ASCII);
135
+ LOG(INFO) << op << " " << this << ": " << data;
136
+ gpr_free(data);
137
+ }
138
+ } else {
139
+ grpc_slice first = GRPC_SLICE_MALLOC(64);
140
+ grpc_slice_buffer_copy_first_into_buffer(slices, 64,
141
+ GRPC_SLICE_START_PTR(first));
142
+ char* data = grpc_dump_slice(first, GPR_DUMP_HEX | GPR_DUMP_ASCII);
143
+ LOG(INFO) << op << " first:" << this << ": " << data;
144
+ gpr_free(data);
145
+ CSliceUnref(first);
146
+ }
147
+ }
182
148
  }
183
- }
184
149
 
185
- static void secure_endpoint_ref(secure_endpoint* ep) { gpr_ref(&ep->ref); }
186
- #endif
150
+ void MaybePostReclaimer() {
151
+ if (!has_posted_reclaimer_.exchange(true, std::memory_order_relaxed)) {
152
+ memory_owner_.PostReclaimer(
153
+ ReclamationPass::kBenign,
154
+ [self = Ref()](std::optional<ReclamationSweep> sweep) {
155
+ if (sweep.has_value()) {
156
+ GRPC_TRACE_LOG(resource_quota, INFO)
157
+ << "secure endpoint: benign reclamation to free memory";
158
+ grpc_slice temp_read_slice;
159
+ grpc_slice temp_write_slice;
187
160
 
188
- static void maybe_post_reclaimer(secure_endpoint* ep) {
189
- if (!ep->has_posted_reclaimer) {
190
- SECURE_ENDPOINT_REF(ep, "benign_reclaimer");
191
- ep->has_posted_reclaimer.exchange(true, std::memory_order_relaxed);
192
- ep->memory_owner.PostReclaimer(
193
- grpc_core::ReclamationPass::kBenign,
194
- [ep](std::optional<grpc_core::ReclamationSweep> sweep) {
195
- if (sweep.has_value()) {
196
- GRPC_TRACE_LOG(resource_quota, INFO)
197
- << "secure endpoint: benign reclamation to free memory";
198
- grpc_slice temp_read_slice;
199
- grpc_slice temp_write_slice;
200
-
201
- ep->read_mu.Lock();
202
- temp_read_slice = ep->read_staging_buffer;
203
- ep->read_staging_buffer = grpc_empty_slice();
204
- ep->read_mu.Unlock();
205
-
206
- ep->write_mu.Lock();
207
- temp_write_slice = ep->write_staging_buffer;
208
- ep->write_staging_buffer = grpc_empty_slice();
209
- ep->write_mu.Unlock();
210
-
211
- grpc_core::CSliceUnref(temp_read_slice);
212
- grpc_core::CSliceUnref(temp_write_slice);
213
- ep->has_posted_reclaimer.exchange(false, std::memory_order_relaxed);
214
- }
215
- SECURE_ENDPOINT_UNREF(ep, "benign_reclaimer");
216
- });
217
- }
218
- }
161
+ self->read_mu_.Lock();
162
+ temp_read_slice =
163
+ std::exchange(self->read_staging_buffer_, grpc_empty_slice());
164
+ self->read_mu_.Unlock();
219
165
 
220
- static void flush_read_staging_buffer(secure_endpoint* ep, uint8_t** cur,
221
- uint8_t** end)
222
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(ep->read_mu) {
223
- grpc_slice_buffer_add_indexed(ep->read_buffer, ep->read_staging_buffer);
224
- ep->read_staging_buffer =
225
- ep->memory_owner.MakeSlice(grpc_core::MemoryRequest(STAGING_BUFFER_SIZE));
226
- *cur = GRPC_SLICE_START_PTR(ep->read_staging_buffer);
227
- *end = GRPC_SLICE_END_PTR(ep->read_staging_buffer);
228
- }
166
+ self->write_mu_.Lock();
167
+ temp_write_slice = std::exchange(self->write_staging_buffer_,
168
+ grpc_empty_slice());
169
+ self->write_mu_.Unlock();
229
170
 
230
- static void call_read_cb(secure_endpoint* ep, grpc_error_handle error) {
231
- if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint) && ABSL_VLOG_IS_ON(2)) {
232
- size_t i;
233
- for (i = 0; i < ep->read_buffer->count; i++) {
234
- char* data = grpc_dump_slice(ep->read_buffer->slices[i],
235
- GPR_DUMP_HEX | GPR_DUMP_ASCII);
236
- VLOG(2) << "READ " << ep << ": " << data;
237
- gpr_free(data);
171
+ CSliceUnref(temp_read_slice);
172
+ CSliceUnref(temp_write_slice);
173
+ self->has_posted_reclaimer_.store(false,
174
+ std::memory_order_relaxed);
175
+ }
176
+ });
238
177
  }
239
178
  }
240
- ep->read_buffer = nullptr;
241
- grpc_core::ExecCtx::Run(DEBUG_LOCATION, ep->read_cb, error);
242
- SECURE_ENDPOINT_UNREF(ep, "read");
243
- }
244
179
 
245
- static void on_read(void* user_data, grpc_error_handle error) {
246
- unsigned i;
247
- uint8_t keep_looping = 0;
248
- tsi_result result = TSI_OK;
249
- secure_endpoint* ep = static_cast<secure_endpoint*>(user_data);
180
+ void FlushReadStagingBuffer(uint8_t** cur, uint8_t** end)
181
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(read_mu_) {
182
+ grpc_slice_buffer_add_indexed(read_buffer_, read_staging_buffer_);
183
+ read_staging_buffer_ =
184
+ memory_owner_.MakeSlice(MemoryRequest(STAGING_BUFFER_SIZE));
185
+ *cur = GRPC_SLICE_START_PTR(read_staging_buffer_);
186
+ *end = GRPC_SLICE_END_PTR(read_staging_buffer_);
187
+ }
250
188
 
251
- {
252
- grpc_core::MutexLock l(&ep->read_mu);
189
+ void FinishRead(bool ok) {
190
+ TraceOp("FinishRead", read_buffer_);
191
+ // TODO(yangg) experiment with moving this block after read_cb to see if it
192
+ // helps latency
193
+ source_buffer_.Clear();
194
+ if (!ok) grpc_slice_buffer_reset_and_unref(read_buffer_);
195
+ read_buffer_ = nullptr;
196
+ }
253
197
 
254
- // If we were shut down after this callback was scheduled with OK
255
- // status but before it was invoked, we need to treat that as an error.
256
- if (ep->wrapped_ep == nullptr && error.ok()) {
257
- error = absl::CancelledError("secure endpoint shutdown");
198
+ absl::Status Unprotect(absl::Status read_status)
199
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(read_mu_) {
200
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("unprotect");
201
+
202
+ if (shutdown_) {
203
+ return absl::CancelledError("secure endpoint shutdown");
258
204
  }
259
205
 
260
- uint8_t* cur = GRPC_SLICE_START_PTR(ep->read_staging_buffer);
261
- uint8_t* end = GRPC_SLICE_END_PTR(ep->read_staging_buffer);
206
+ GRPC_TRACE_LOG(secure_endpoint, INFO) << "Starting unprotect for " << this;
207
+ bool keep_looping = false;
208
+ tsi_result result = TSI_OK;
209
+
210
+ uint8_t* cur = GRPC_SLICE_START_PTR(read_staging_buffer_);
211
+ uint8_t* end = GRPC_SLICE_END_PTR(read_staging_buffer_);
262
212
 
263
- if (!error.ok()) {
264
- grpc_slice_buffer_reset_and_unref(ep->read_buffer);
265
- } else if (ep->zero_copy_protector != nullptr) {
213
+ if (!read_status.ok()) {
214
+ grpc_slice_buffer_reset_and_unref(read_buffer_);
215
+ } else if (zero_copy_protector_ != nullptr) {
266
216
  // Use zero-copy grpc protector to unprotect.
267
217
  int min_progress_size = 1;
268
218
  // Get the size of the last frame which is not yet fully decrypted.
@@ -270,18 +220,18 @@ static void on_read(void* user_data, grpc_error_handle error) {
270
220
  // passed to the TCP layer to indicate the minimum number of
271
221
  // bytes that need to be read to make meaningful progress. This would
272
222
  // avoid reading of small slices from the network.
273
- // TODO(vigneshbabu): Set min_progress_size in the regular (non-zero-copy)
274
- // frame protector code path as well.
223
+ // TODO(vigneshbabu): Set min_progress_size in the regular
224
+ // (non-zero-copy) frame protector code path as well.
275
225
  result = tsi_zero_copy_grpc_protector_unprotect(
276
- ep->zero_copy_protector, &ep->source_buffer, ep->read_buffer,
226
+ zero_copy_protector_, source_buffer_.c_slice_buffer(), read_buffer_,
277
227
  &min_progress_size);
278
228
  min_progress_size = std::max(1, min_progress_size);
279
- ep->min_progress_size = result != TSI_OK ? 1 : min_progress_size;
229
+ min_progress_size_ = result != TSI_OK ? 1 : min_progress_size;
280
230
  } else {
281
231
  // Use frame protector to unprotect.
282
232
  // TODO(yangg) check error, maybe bail out early
283
- for (i = 0; i < ep->source_buffer.count; i++) {
284
- grpc_slice encrypted = ep->source_buffer.slices[i];
233
+ for (size_t i = 0; i < source_buffer_.Count(); i++) {
234
+ grpc_slice encrypted = source_buffer_.c_slice_buffer()->slices[i];
285
235
  uint8_t* message_bytes = GRPC_SLICE_START_PTR(encrypted);
286
236
  size_t message_size = GRPC_SLICE_LENGTH(encrypted);
287
237
 
@@ -289,11 +239,17 @@ static void on_read(void* user_data, grpc_error_handle error) {
289
239
  size_t unprotected_buffer_size_written =
290
240
  static_cast<size_t>(end - cur);
291
241
  size_t processed_message_size = message_size;
292
- gpr_mu_lock(&ep->protector_mu);
293
- result = tsi_frame_protector_unprotect(
294
- ep->protector, message_bytes, &processed_message_size, cur,
295
- &unprotected_buffer_size_written);
296
- gpr_mu_unlock(&ep->protector_mu);
242
+ if (IsTsiFrameProtectorWithoutLocksEnabled()) {
243
+ result = tsi_frame_protector_unprotect(
244
+ protector_, message_bytes, &processed_message_size, cur,
245
+ &unprotected_buffer_size_written);
246
+ } else {
247
+ protector_mu_.Lock();
248
+ result = tsi_frame_protector_unprotect(
249
+ protector_, message_bytes, &processed_message_size, cur,
250
+ &unprotected_buffer_size_written);
251
+ protector_mu_.Unlock();
252
+ }
297
253
  if (result != TSI_OK) {
298
254
  LOG(ERROR) << "Decryption error: " << tsi_result_to_string(result);
299
255
  break;
@@ -303,152 +259,133 @@ static void on_read(void* user_data, grpc_error_handle error) {
303
259
  cur += unprotected_buffer_size_written;
304
260
 
305
261
  if (cur == end) {
306
- flush_read_staging_buffer(ep, &cur, &end);
262
+ FlushReadStagingBuffer(&cur, &end);
307
263
  // Force to enter the loop again to extract buffered bytes in
308
- // protector. The bytes could be buffered because of running out of
309
- // staging_buffer. If this happens at the end of all slices, doing
310
- // another unprotect avoids leaving data in the protector.
311
- keep_looping = 1;
264
+ // protector. The bytes could be buffered because of running out
265
+ // of staging_buffer. If this happens at the end of all slices,
266
+ // doing another unprotect avoids leaving data in the protector.
267
+ keep_looping = true;
312
268
  } else if (unprotected_buffer_size_written > 0) {
313
- keep_looping = 1;
269
+ keep_looping = true;
314
270
  } else {
315
- keep_looping = 0;
271
+ keep_looping = false;
316
272
  }
317
273
  }
318
274
  if (result != TSI_OK) break;
319
275
  }
320
276
 
321
- if (cur != GRPC_SLICE_START_PTR(ep->read_staging_buffer)) {
277
+ if (cur != GRPC_SLICE_START_PTR(read_staging_buffer_)) {
322
278
  grpc_slice_buffer_add(
323
- ep->read_buffer,
279
+ read_buffer_,
324
280
  grpc_slice_split_head(
325
- &ep->read_staging_buffer,
281
+ &read_staging_buffer_,
326
282
  static_cast<size_t>(
327
- cur - GRPC_SLICE_START_PTR(ep->read_staging_buffer))));
283
+ cur - GRPC_SLICE_START_PTR(read_staging_buffer_))));
328
284
  }
329
285
  }
330
- }
331
286
 
332
- if (!error.ok()) {
333
- call_read_cb(
334
- ep, GRPC_ERROR_CREATE_REFERENCING("Secure read failed", &error, 1));
335
- return;
336
- }
287
+ if (read_status.ok() && result != TSI_OK) {
288
+ read_status = GRPC_ERROR_CREATE(
289
+ absl::StrCat("Unwrap failed (", tsi_result_to_string(result), ")"));
290
+ }
337
291
 
338
- // TODO(yangg) experiment with moving this block after read_cb to see if it
339
- // helps latency
340
- grpc_slice_buffer_reset_and_unref(&ep->source_buffer);
292
+ GRPC_TRACE_LOG(secure_endpoint, INFO)
293
+ << "Unprotect: " << this << " read_status: " << read_status;
341
294
 
342
- if (result != TSI_OK) {
343
- grpc_slice_buffer_reset_and_unref(ep->read_buffer);
344
- call_read_cb(
345
- ep, GRPC_ERROR_CREATE(absl::StrCat("Unwrap failed (",
346
- tsi_result_to_string(result), ")")));
347
- return;
295
+ return read_status;
348
296
  }
349
297
 
350
- call_read_cb(ep, absl::OkStatus());
351
- }
298
+ void BeginRead(grpc_slice_buffer* slices) {
299
+ read_buffer_ = slices;
300
+ grpc_slice_buffer_reset_and_unref(read_buffer_);
301
+ }
352
302
 
353
- static void endpoint_read(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
354
- grpc_closure* cb, bool urgent,
355
- int /*min_progress_size*/) {
356
- secure_endpoint* ep = reinterpret_cast<secure_endpoint*>(secure_ep);
357
- ep->read_cb = cb;
358
- ep->read_buffer = slices;
359
- grpc_slice_buffer_reset_and_unref(ep->read_buffer);
303
+ bool IsZeroCopyProtector() const { return is_zero_copy_protector_; }
360
304
 
361
- SECURE_ENDPOINT_REF(ep, "read");
362
- if (ep->leftover_bytes.count) {
363
- grpc_slice_buffer_swap(&ep->leftover_bytes, &ep->source_buffer);
364
- CHECK_EQ(ep->leftover_bytes.count, 0u);
365
- on_read(ep, absl::OkStatus());
366
- return;
305
+ bool MaybeCompleteReadImmediately() {
306
+ GRPC_TRACE_LOG(secure_endpoint, INFO)
307
+ << "MaybeCompleteReadImmediately: " << this
308
+ << " leftover_bytes_: " << leftover_bytes_.get();
309
+ if (leftover_bytes_ != nullptr) {
310
+ grpc_slice_buffer_swap(leftover_bytes_->c_slice_buffer(),
311
+ source_buffer_.c_slice_buffer());
312
+ leftover_bytes_.reset();
313
+ return true;
314
+ }
315
+ return false;
367
316
  }
368
317
 
369
- grpc_endpoint_read(ep->wrapped_ep.get(), &ep->source_buffer, &ep->on_read,
370
- urgent, /*min_progress_size=*/ep->min_progress_size);
371
- }
318
+ grpc_event_engine::experimental::SliceBuffer* source_buffer() {
319
+ return &source_buffer_;
320
+ }
372
321
 
373
- static void flush_write_staging_buffer(secure_endpoint* ep, uint8_t** cur,
374
- uint8_t** end)
375
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(ep->write_mu) {
376
- grpc_slice_buffer_add_indexed(&ep->output_buffer, ep->write_staging_buffer);
377
- ep->write_staging_buffer =
378
- ep->memory_owner.MakeSlice(grpc_core::MemoryRequest(STAGING_BUFFER_SIZE));
379
- *cur = GRPC_SLICE_START_PTR(ep->write_staging_buffer);
380
- *end = GRPC_SLICE_END_PTR(ep->write_staging_buffer);
381
- maybe_post_reclaimer(ep);
382
- }
322
+ int min_progress_size() const { return min_progress_size_; }
383
323
 
384
- static void on_write(void* user_data, grpc_error_handle error) {
385
- secure_endpoint* ep = static_cast<secure_endpoint*>(user_data);
386
- grpc_closure* cb = ep->write_cb;
387
- ep->write_cb = nullptr;
388
- SECURE_ENDPOINT_UNREF(ep, "write");
389
- grpc_core::EnsureRunInExecCtx([cb, error = std::move(error)]() {
390
- grpc_core::Closure::Run(DEBUG_LOCATION, cb, error);
391
- });
392
- }
324
+ void FlushWriteStagingBuffer(uint8_t** cur, uint8_t** end)
325
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(write_mu_) {
326
+ output_buffer_.AppendIndexed(
327
+ grpc_event_engine::experimental::Slice(write_staging_buffer_));
328
+ write_staging_buffer_ =
329
+ memory_owner_.MakeSlice(MemoryRequest(STAGING_BUFFER_SIZE));
330
+ *cur = GRPC_SLICE_START_PTR(write_staging_buffer_);
331
+ *end = GRPC_SLICE_END_PTR(write_staging_buffer_);
332
+ MaybePostReclaimer();
333
+ }
393
334
 
394
- static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
395
- grpc_closure* cb, void* arg, int max_frame_size) {
396
- GRPC_LATENT_SEE_INNER_SCOPE("secure_endpoint write");
397
- unsigned i;
398
- tsi_result result = TSI_OK;
399
- secure_endpoint* ep = reinterpret_cast<secure_endpoint*>(secure_ep);
335
+ tsi_result Protect(grpc_slice_buffer* slices, int max_frame_size)
336
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(write_mu_) {
337
+ if (shutdown_) return TSI_FAILED_PRECONDITION;
400
338
 
401
- {
402
- grpc_core::MutexLock l(&ep->write_mu);
403
- uint8_t* cur = GRPC_SLICE_START_PTR(ep->write_staging_buffer);
404
- uint8_t* end = GRPC_SLICE_END_PTR(ep->write_staging_buffer);
339
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("protect");
340
+ GRPC_TRACE_LOG(secure_endpoint, INFO) << "Starting protect for " << this;
341
+ uint8_t* cur = GRPC_SLICE_START_PTR(write_staging_buffer_);
342
+ uint8_t* end = GRPC_SLICE_END_PTR(write_staging_buffer_);
405
343
 
406
- grpc_slice_buffer_reset_and_unref(&ep->output_buffer);
344
+ output_buffer_.Clear();
407
345
 
408
- if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint) && ABSL_VLOG_IS_ON(2)) {
409
- for (i = 0; i < slices->count; i++) {
410
- char* data =
411
- grpc_dump_slice(slices->slices[i], GPR_DUMP_HEX | GPR_DUMP_ASCII);
412
- VLOG(2) << "WRITE " << ep << ": " << data;
413
- gpr_free(data);
414
- }
415
- }
346
+ TraceOp("Protect", slices);
416
347
 
417
- if (ep->zero_copy_protector != nullptr) {
348
+ tsi_result result = TSI_OK;
349
+ if (zero_copy_protector_ != nullptr) {
418
350
  // Use zero-copy grpc protector to protect.
419
- result = TSI_OK;
420
351
  // Break the input slices into chunks of size = max_frame_size and call
421
352
  // tsi_zero_copy_grpc_protector_protect on each chunk. This ensures that
422
353
  // the protector cannot create frames larger than the specified
423
354
  // max_frame_size.
424
355
  while (slices->length > static_cast<size_t>(max_frame_size) &&
425
356
  result == TSI_OK) {
426
- grpc_slice_buffer_move_first(slices,
427
- static_cast<size_t>(max_frame_size),
428
- &ep->protector_staging_buffer);
357
+ grpc_slice_buffer_move_first(
358
+ slices, static_cast<size_t>(max_frame_size),
359
+ protector_staging_buffer_.c_slice_buffer());
429
360
  result = tsi_zero_copy_grpc_protector_protect(
430
- ep->zero_copy_protector, &ep->protector_staging_buffer,
431
- &ep->output_buffer);
361
+ zero_copy_protector_, protector_staging_buffer_.c_slice_buffer(),
362
+ output_buffer_.c_slice_buffer());
432
363
  }
433
364
  if (result == TSI_OK && slices->length > 0) {
434
365
  result = tsi_zero_copy_grpc_protector_protect(
435
- ep->zero_copy_protector, slices, &ep->output_buffer);
366
+ zero_copy_protector_, slices, output_buffer_.c_slice_buffer());
436
367
  }
437
- grpc_slice_buffer_reset_and_unref(&ep->protector_staging_buffer);
368
+ protector_staging_buffer_.Clear();
438
369
  } else {
439
370
  // Use frame protector to protect.
440
- for (i = 0; i < slices->count; i++) {
371
+ for (size_t i = 0; i < slices->count; i++) {
441
372
  grpc_slice plain = slices->slices[i];
442
373
  uint8_t* message_bytes = GRPC_SLICE_START_PTR(plain);
443
374
  size_t message_size = GRPC_SLICE_LENGTH(plain);
444
375
  while (message_size > 0) {
445
376
  size_t protected_buffer_size_to_send = static_cast<size_t>(end - cur);
446
377
  size_t processed_message_size = message_size;
447
- gpr_mu_lock(&ep->protector_mu);
448
- result = tsi_frame_protector_protect(ep->protector, message_bytes,
449
- &processed_message_size, cur,
450
- &protected_buffer_size_to_send);
451
- gpr_mu_unlock(&ep->protector_mu);
378
+ if (IsTsiFrameProtectorWithoutLocksEnabled()) {
379
+ result = tsi_frame_protector_protect(
380
+ protector_, message_bytes, &processed_message_size, cur,
381
+ &protected_buffer_size_to_send);
382
+ } else {
383
+ protector_mu_.Lock();
384
+ result = tsi_frame_protector_protect(
385
+ protector_, message_bytes, &processed_message_size, cur,
386
+ &protected_buffer_size_to_send);
387
+ protector_mu_.Unlock();
388
+ }
452
389
  if (result != TSI_OK) {
453
390
  LOG(ERROR) << "Encryption error: " << tsi_result_to_string(result);
454
391
  break;
@@ -458,7 +395,7 @@ static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
458
395
  cur += protected_buffer_size_to_send;
459
396
 
460
397
  if (cur == end) {
461
- flush_write_staging_buffer(ep, &cur, &end);
398
+ FlushWriteStagingBuffer(&cur, &end);
462
399
  }
463
400
  }
464
401
  if (result != TSI_OK) break;
@@ -467,32 +404,215 @@ static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
467
404
  size_t still_pending_size;
468
405
  do {
469
406
  size_t protected_buffer_size_to_send = static_cast<size_t>(end - cur);
470
- gpr_mu_lock(&ep->protector_mu);
471
- result = tsi_frame_protector_protect_flush(
472
- ep->protector, cur, &protected_buffer_size_to_send,
473
- &still_pending_size);
474
- gpr_mu_unlock(&ep->protector_mu);
407
+ if (IsTsiFrameProtectorWithoutLocksEnabled()) {
408
+ result = tsi_frame_protector_protect_flush(
409
+ protector_, cur, &protected_buffer_size_to_send,
410
+ &still_pending_size);
411
+ } else {
412
+ protector_mu_.Lock();
413
+ result = tsi_frame_protector_protect_flush(
414
+ protector_, cur, &protected_buffer_size_to_send,
415
+ &still_pending_size);
416
+ protector_mu_.Unlock();
417
+ }
475
418
  if (result != TSI_OK) break;
476
419
  cur += protected_buffer_size_to_send;
477
420
  if (cur == end) {
478
- flush_write_staging_buffer(ep, &cur, &end);
421
+ FlushWriteStagingBuffer(&cur, &end);
479
422
  }
480
423
  } while (still_pending_size > 0);
481
- if (cur != GRPC_SLICE_START_PTR(ep->write_staging_buffer)) {
482
- grpc_slice_buffer_add(
483
- &ep->output_buffer,
484
- grpc_slice_split_head(
485
- &ep->write_staging_buffer,
424
+ if (cur != GRPC_SLICE_START_PTR(write_staging_buffer_)) {
425
+ output_buffer_.Append(
426
+ grpc_event_engine::experimental::Slice(grpc_slice_split_head(
427
+ &write_staging_buffer_,
486
428
  static_cast<size_t>(
487
- cur - GRPC_SLICE_START_PTR(ep->write_staging_buffer))));
429
+ cur - GRPC_SLICE_START_PTR(write_staging_buffer_)))));
488
430
  }
489
431
  }
490
432
  }
433
+ // TODO(yangg) do different things according to the error type?
434
+ if (result != TSI_OK) output_buffer_.Clear();
435
+
436
+ GRPC_TRACE_LOG(secure_endpoint, INFO)
437
+ << "Protect: " << this << " result: " << result;
438
+
439
+ return result;
440
+ }
441
+
442
+ grpc_event_engine::experimental::SliceBuffer* output_buffer() {
443
+ return &output_buffer_;
444
+ }
445
+
446
+ void Shutdown() {
447
+ shutdown_ = true;
448
+ memory_owner_.Reset();
449
+ }
450
+
451
+ private:
452
+ struct tsi_frame_protector* const protector_;
453
+ struct tsi_zero_copy_grpc_protector* const zero_copy_protector_;
454
+ Mutex mu_;
455
+ Mutex read_mu_;
456
+ Mutex write_mu_;
457
+ Mutex protector_mu_;
458
+ grpc_slice_buffer* read_buffer_ = nullptr;
459
+ grpc_event_engine::experimental::SliceBuffer source_buffer_;
460
+ // saved handshaker leftover data to unprotect.
461
+ std::unique_ptr<SliceBuffer> leftover_bytes_;
462
+ // buffers for read and write
463
+ grpc_slice read_staging_buffer_ ABSL_GUARDED_BY(read_mu_);
464
+ grpc_slice write_staging_buffer_ ABSL_GUARDED_BY(write_mu_);
465
+ grpc_event_engine::experimental::SliceBuffer output_buffer_;
466
+ MemoryOwner memory_owner_;
467
+ MemoryAllocator::Reservation self_reservation_;
468
+ std::atomic<bool> has_posted_reclaimer_{false};
469
+ int min_progress_size_ = 1;
470
+ SliceBuffer protector_staging_buffer_;
471
+ bool shutdown_ = false;
472
+ bool is_zero_copy_protector_ = false;
473
+ };
474
+ } // namespace
475
+ } // namespace grpc_core
476
+
477
+ namespace {
478
+ struct secure_endpoint : public grpc_endpoint {
479
+ secure_endpoint(const grpc_endpoint_vtable* vtbl,
480
+ tsi_frame_protector* protector,
481
+ tsi_zero_copy_grpc_protector* zero_copy_protector,
482
+ grpc_core::OrphanablePtr<grpc_endpoint> endpoint,
483
+ grpc_slice* leftover_slices, size_t leftover_nslices,
484
+ const grpc_core::ChannelArgs& args)
485
+ : wrapped_ep(std::move(endpoint)),
486
+ frame_protector(protector, zero_copy_protector, leftover_slices,
487
+ leftover_nslices, args) {
488
+ this->vtable = vtbl;
489
+ GRPC_CLOSURE_INIT(&on_read, ::on_read, this, grpc_schedule_on_exec_ctx);
490
+ GRPC_CLOSURE_INIT(&on_write, ::on_write, this, grpc_schedule_on_exec_ctx);
491
+ gpr_ref_init(&ref, 1);
492
+ }
493
+
494
+ ~secure_endpoint() {}
495
+
496
+ grpc_core::OrphanablePtr<grpc_endpoint> wrapped_ep;
497
+ grpc_core::FrameProtector frame_protector;
498
+ // saved upper level callbacks and user_data.
499
+ grpc_closure* read_cb = nullptr;
500
+ grpc_closure* write_cb = nullptr;
501
+ grpc_closure on_read;
502
+ grpc_closure on_write;
503
+ gpr_refcount ref;
504
+ };
505
+ } // namespace
506
+
507
+ static void destroy(secure_endpoint* ep) { delete ep; }
508
+
509
+ #ifndef NDEBUG
510
+ #define SECURE_ENDPOINT_UNREF(ep, reason) \
511
+ secure_endpoint_unref((ep), (reason), __FILE__, __LINE__)
512
+ #define SECURE_ENDPOINT_REF(ep, reason) \
513
+ secure_endpoint_ref((ep), (reason), __FILE__, __LINE__)
514
+ static void secure_endpoint_unref(secure_endpoint* ep, const char* reason,
515
+ const char* file, int line) {
516
+ if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint)) {
517
+ gpr_atm val = gpr_atm_no_barrier_load(&ep->ref.count);
518
+ VLOG(2).AtLocation(file, line) << "SECENDP unref " << ep << " : " << reason
519
+ << " " << val << " -> " << val - 1;
520
+ }
521
+ if (gpr_unref(&ep->ref)) {
522
+ destroy(ep);
523
+ }
524
+ }
525
+
526
+ static void secure_endpoint_ref(secure_endpoint* ep, const char* reason,
527
+ const char* file, int line) {
528
+ if (GRPC_TRACE_FLAG_ENABLED(secure_endpoint)) {
529
+ gpr_atm val = gpr_atm_no_barrier_load(&ep->ref.count);
530
+ VLOG(2).AtLocation(file, line) << "SECENDP ref " << ep << " : " << reason
531
+ << " " << val << " -> " << val + 1;
532
+ }
533
+ gpr_ref(&ep->ref);
534
+ }
535
+ #else
536
+ #define SECURE_ENDPOINT_UNREF(ep, reason) secure_endpoint_unref((ep))
537
+ #define SECURE_ENDPOINT_REF(ep, reason) secure_endpoint_ref((ep))
538
+ static void secure_endpoint_unref(secure_endpoint* ep) {
539
+ if (gpr_unref(&ep->ref)) {
540
+ destroy(ep);
541
+ }
542
+ }
543
+
544
+ static void secure_endpoint_ref(secure_endpoint* ep) { gpr_ref(&ep->ref); }
545
+ #endif
546
+
547
+ static void call_read_cb(secure_endpoint* ep, grpc_error_handle error) {
548
+ ep->frame_protector.FinishRead(error.ok());
549
+ grpc_core::ExecCtx::Run(DEBUG_LOCATION, ep->read_cb, error);
550
+ SECURE_ENDPOINT_UNREF(ep, "read");
551
+ }
552
+
553
+ static void on_read(void* user_data, grpc_error_handle error) {
554
+ secure_endpoint* ep = reinterpret_cast<secure_endpoint*>(user_data);
555
+
556
+ {
557
+ grpc_core::MutexLock lock(ep->frame_protector.read_mu());
558
+ // If we were shut down after this callback was scheduled with OK
559
+ // status but before it was invoked, we need to treat that as an error.
560
+ if (ep->wrapped_ep == nullptr && error.ok()) {
561
+ error = absl::CancelledError("secure endpoint shutdown");
562
+ }
563
+ error = ep->frame_protector.Unprotect(std::move(error));
564
+ }
565
+
566
+ if (!error.ok()) {
567
+ call_read_cb(
568
+ ep, GRPC_ERROR_CREATE_REFERENCING("Secure read failed", &error, 1));
569
+ return;
570
+ }
571
+
572
+ call_read_cb(ep, absl::OkStatus());
573
+ }
574
+
575
+ static void endpoint_read(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
576
+ grpc_closure* cb, bool urgent,
577
+ int /*min_progress_size*/) {
578
+ secure_endpoint* ep = reinterpret_cast<secure_endpoint*>(secure_ep);
579
+ ep->read_cb = cb;
580
+ ep->frame_protector.BeginRead(slices);
581
+
582
+ SECURE_ENDPOINT_REF(ep, "read");
583
+ if (ep->frame_protector.MaybeCompleteReadImmediately()) {
584
+ on_read(ep, absl::OkStatus());
585
+ return;
586
+ }
587
+
588
+ grpc_endpoint_read(ep->wrapped_ep.get(),
589
+ ep->frame_protector.source_buffer()->c_slice_buffer(),
590
+ &ep->on_read, urgent,
591
+ ep->frame_protector.min_progress_size());
592
+ }
593
+
594
+ static void on_write(void* user_data, grpc_error_handle error) {
595
+ secure_endpoint* ep = static_cast<secure_endpoint*>(user_data);
596
+ grpc_closure* cb = ep->write_cb;
597
+ ep->write_cb = nullptr;
598
+ SECURE_ENDPOINT_UNREF(ep, "write");
599
+ grpc_core::EnsureRunInExecCtx([cb, error = std::move(error)]() {
600
+ grpc_core::Closure::Run(DEBUG_LOCATION, cb, error);
601
+ });
602
+ }
603
+
604
+ static void endpoint_write(
605
+ grpc_endpoint* secure_ep, grpc_slice_buffer* slices, grpc_closure* cb,
606
+ grpc_event_engine::experimental::EventEngine::Endpoint::WriteArgs args) {
607
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("secure_endpoint write");
608
+ secure_endpoint* ep = reinterpret_cast<secure_endpoint*>(secure_ep);
609
+ tsi_result result;
610
+ {
611
+ grpc_core::MutexLock lock(ep->frame_protector.write_mu());
612
+ result = ep->frame_protector.Protect(slices, args.max_frame_size());
491
613
  }
492
614
 
493
615
  if (result != TSI_OK) {
494
- // TODO(yangg) do different things according to the error type?
495
- grpc_slice_buffer_reset_and_unref(&ep->output_buffer);
496
616
  grpc_core::ExecCtx::Run(
497
617
  DEBUG_LOCATION, cb,
498
618
  GRPC_ERROR_CREATE(
@@ -504,16 +624,17 @@ static void endpoint_write(grpc_endpoint* secure_ep, grpc_slice_buffer* slices,
504
624
  // output_buffer at any time until the write completes.
505
625
  SECURE_ENDPOINT_REF(ep, "write");
506
626
  ep->write_cb = cb;
507
- grpc_endpoint_write(ep->wrapped_ep.get(), &ep->output_buffer, &ep->on_write,
508
- arg, max_frame_size);
627
+ grpc_endpoint_write(ep->wrapped_ep.get(),
628
+ ep->frame_protector.output_buffer()->c_slice_buffer(),
629
+ &ep->on_write, std::move(args));
509
630
  }
510
631
 
511
632
  static void endpoint_destroy(grpc_endpoint* secure_ep) {
512
633
  secure_endpoint* ep = reinterpret_cast<secure_endpoint*>(secure_ep);
513
- ep->read_mu.Lock();
634
+ ep->frame_protector.read_mu()->Lock();
514
635
  ep->wrapped_ep.reset();
515
- ep->memory_owner.Reset();
516
- ep->read_mu.Unlock();
636
+ ep->frame_protector.Shutdown();
637
+ ep->frame_protector.read_mu()->Unlock();
517
638
  SECURE_ENDPOINT_UNREF(ep, "destroy");
518
639
  }
519
640
 
@@ -566,13 +687,429 @@ static const grpc_endpoint_vtable vtable = {endpoint_read,
566
687
  endpoint_get_fd,
567
688
  endpoint_can_track_err};
568
689
 
690
+ namespace grpc_event_engine::experimental {
691
+ namespace {
692
+
693
+ class SecureEndpoint final : public EventEngine::Endpoint {
694
+ public:
695
+ SecureEndpoint(
696
+ std::unique_ptr<grpc_event_engine::experimental::EventEngine::Endpoint>
697
+ wrapped_ep,
698
+ struct tsi_frame_protector* protector,
699
+ struct tsi_zero_copy_grpc_protector* zero_copy_protector,
700
+ grpc_slice* leftover_slices, size_t leftover_nslices,
701
+ const grpc_core::ChannelArgs& channel_args)
702
+ : impl_(grpc_core::MakeRefCounted<Impl>(
703
+ std::move(wrapped_ep), protector, zero_copy_protector,
704
+ leftover_slices, leftover_nslices, channel_args)) {}
705
+
706
+ ~SecureEndpoint() override { impl_->Shutdown(); }
707
+
708
+ bool Read(absl::AnyInvocable<void(absl::Status)> on_read, SliceBuffer* buffer,
709
+ ReadArgs in_args) override {
710
+ return impl_->Read(std::move(on_read), buffer, std::move(in_args));
711
+ }
712
+
713
+ bool Write(absl::AnyInvocable<void(absl::Status)> on_writable,
714
+ SliceBuffer* data, WriteArgs args) override {
715
+ return impl_->Write(std::move(on_writable), data, std::move(args));
716
+ }
717
+
718
+ const EventEngine::ResolvedAddress& GetPeerAddress() const override {
719
+ return impl_->GetPeerAddress();
720
+ }
721
+
722
+ const EventEngine::ResolvedAddress& GetLocalAddress() const override {
723
+ return impl_->GetLocalAddress();
724
+ }
725
+
726
+ void* QueryExtension(absl::string_view id) override {
727
+ return impl_->QueryExtension(id);
728
+ }
729
+
730
+ std::shared_ptr<TelemetryInfo> GetTelemetryInfo() const override {
731
+ return std::make_shared<Impl::TelemetryInfo>(impl_->GetTelemetryInfo());
732
+ }
733
+
734
+ private:
735
+ class Impl : public grpc_core::RefCounted<Impl> {
736
+ public:
737
+ class TelemetryInfo : public EventEngine::Endpoint::TelemetryInfo {
738
+ public:
739
+ explicit TelemetryInfo(
740
+ std::shared_ptr<EventEngine::Endpoint::TelemetryInfo>
741
+ wrapped_telemetry_info)
742
+ : wrapped_telemetry_info_(std::move(wrapped_telemetry_info)) {}
743
+
744
+ std::vector<size_t> AllWriteMetrics() const override {
745
+ return wrapped_telemetry_info_
746
+ ? wrapped_telemetry_info_->AllWriteMetrics()
747
+ : std::vector<size_t>{};
748
+ }
749
+
750
+ std::optional<absl::string_view> GetMetricName(
751
+ size_t key) const override {
752
+ return wrapped_telemetry_info_
753
+ ? wrapped_telemetry_info_->GetMetricName(key)
754
+ : std::nullopt;
755
+ }
756
+
757
+ std::optional<size_t> GetMetricKey(
758
+ absl::string_view name) const override {
759
+ return wrapped_telemetry_info_
760
+ ? wrapped_telemetry_info_->GetMetricKey(name)
761
+ : std::nullopt;
762
+ }
763
+
764
+ std::shared_ptr<EventEngine::Endpoint::MetricsSet> GetMetricsSet(
765
+ absl::Span<const size_t> keys) const override {
766
+ return wrapped_telemetry_info_
767
+ ? wrapped_telemetry_info_->GetMetricsSet(keys)
768
+ : nullptr;
769
+ }
770
+
771
+ std::shared_ptr<EventEngine::Endpoint::MetricsSet> GetFullMetricsSet()
772
+ const override {
773
+ return wrapped_telemetry_info_
774
+ ? wrapped_telemetry_info_->GetFullMetricsSet()
775
+ : nullptr;
776
+ }
777
+
778
+ private:
779
+ std::shared_ptr<EventEngine::Endpoint::TelemetryInfo>
780
+ wrapped_telemetry_info_;
781
+ };
782
+
783
+ Impl(std::unique_ptr<grpc_event_engine::experimental::EventEngine::Endpoint>
784
+ wrapped_ep,
785
+ struct tsi_frame_protector* protector,
786
+ struct tsi_zero_copy_grpc_protector* zero_copy_protector,
787
+ grpc_slice* leftover_slices, size_t leftover_nslices,
788
+ const grpc_core::ChannelArgs& channel_args)
789
+ : frame_protector_(protector, zero_copy_protector, leftover_slices,
790
+ leftover_nslices, channel_args),
791
+ wrapped_ep_(std::move(wrapped_ep)),
792
+ event_engine_(channel_args.GetObjectRef<
793
+ grpc_event_engine::experimental::EventEngine>()),
794
+ large_read_threshold_(std::max(
795
+ 1, channel_args.GetInt(GRPC_ARG_DECRYPTION_OFFLOAD_THRESHOLD)
796
+ .value_or(32 * 1024))),
797
+ large_write_threshold_(std::max(
798
+ 1, channel_args.GetInt(GRPC_ARG_ENCRYPTION_OFFLOAD_THRESHOLD)
799
+ .value_or(32 * 1024))),
800
+ max_buffered_writes_(std::max(
801
+ 0, channel_args
802
+ .GetInt(GRPC_ARG_ENCRYPTION_OFFLOAD_MAX_BUFFERED_WRITES)
803
+ .value_or(1024 * 1024))) {}
804
+
805
+ bool Read(absl::AnyInvocable<void(absl::Status)> on_read,
806
+ SliceBuffer* buffer, ReadArgs args) {
807
+ on_read_ = std::move(on_read);
808
+ frame_protector_.BeginRead(buffer->c_slice_buffer());
809
+ if (frame_protector_.MaybeCompleteReadImmediately()) {
810
+ return MaybeFinishReadImmediately();
811
+ }
812
+ if (frame_protector_.IsZeroCopyProtector()) {
813
+ args.set_read_hint_bytes(frame_protector_.min_progress_size());
814
+ }
815
+ bool read_completed_immediately = wrapped_ep_->Read(
816
+ [impl = Ref()](absl::Status status) mutable {
817
+ grpc_core::ExecCtx exec_ctx;
818
+ FinishAsyncRead(std::move(impl), std::move(status));
819
+ },
820
+ frame_protector_.source_buffer(), std::move(args));
821
+ if (read_completed_immediately) return MaybeFinishReadImmediately();
822
+ return false;
823
+ }
824
+
825
+ bool Write(absl::AnyInvocable<void(absl::Status)> on_writable,
826
+ SliceBuffer* data, WriteArgs args) {
827
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("secure_endpoint write");
828
+ tsi_result result;
829
+ frame_protector_.TraceOp("Write", data->c_slice_buffer());
830
+ if (grpc_core::IsSecureEndpointOffloadLargeWritesEnabled()) {
831
+ // If we get a zero length frame, just complete without looking at
832
+ // anything further
833
+ if (data->Length() == 0) return true;
834
+ grpc_core::MutexLock lock(&write_queue_mu_);
835
+ // If there's been a failure observed asynchronously, then fail out with
836
+ // that error.
837
+ if (!writing_.ok()) {
838
+ event_engine_->Run(
839
+ [on_write = std::move(on_writable),
840
+ status = writing_.status()]() mutable { on_write(status); });
841
+ return false;
842
+ }
843
+ // If we're already writing (== encrypting on another thread) we need to
844
+ // queue the writes up to do after that completes.
845
+ // OR if we're not already writing but this write is large, we push it
846
+ // onto the event engine to encrypt later.
847
+ if (*writing_ || data->Length() > large_write_threshold_) {
848
+ // Since we don't call on_write until we've collected pending_writes
849
+ // in the FinishAsyncWrites path, and EventEngine insists that one
850
+ // write finishes before a second begins, we should never see a Write
851
+ // call here with a non-null pending_writes_.
852
+ GRPC_CHECK(pending_writes_ == nullptr);
853
+ pending_writes_ = std::make_unique<SliceBuffer>(std::move(*data));
854
+ frame_protector_.TraceOp("Pending",
855
+ pending_writes_->c_slice_buffer());
856
+ // Wait for the previous write to finish before considering this one.
857
+ // Note that since EventEngine::Endpoint allows only one outstanding
858
+ // write, this will pause sending until the callback is invoked.
859
+ last_write_args_ = std::move(args);
860
+ on_write_ = std::move(on_writable);
861
+ if (!*writing_) {
862
+ writing_ = true;
863
+ event_engine_->Run([impl = Ref()]() mutable {
864
+ grpc_core::ExecCtx exec_ctx;
865
+ FinishAsyncWrite(std::move(impl));
866
+ });
867
+ }
868
+ return false;
869
+ }
870
+ }
871
+ // A small write: encrypt inline and write to the socket.
872
+ {
873
+ grpc_core::MutexLock lock(frame_protector_.write_mu());
874
+ result = frame_protector_.Protect(data->c_slice_buffer(),
875
+ args.max_frame_size());
876
+ }
877
+ if (result != TSI_OK) {
878
+ event_engine_->Run(
879
+ [on_writable = std::move(on_writable), result]() mutable {
880
+ on_writable(GRPC_ERROR_CREATE(absl::StrCat(
881
+ "Wrap failed (", tsi_result_to_string(result), ")")));
882
+ });
883
+ return false;
884
+ }
885
+ on_write_ = std::move(on_writable);
886
+ frame_protector_.TraceOp(
887
+ "Write", frame_protector_.output_buffer()->c_slice_buffer());
888
+ return wrapped_ep_->Write(
889
+ [impl = Ref()](absl::Status status) mutable {
890
+ auto on_write = std::move(impl->on_write_);
891
+ impl.reset();
892
+ on_write(status);
893
+ },
894
+ frame_protector_.output_buffer(), std::move(args));
895
+ }
896
+
897
+ const EventEngine::ResolvedAddress& GetPeerAddress() const {
898
+ return wrapped_ep_->GetPeerAddress();
899
+ }
900
+
901
+ const EventEngine::ResolvedAddress& GetLocalAddress() const {
902
+ return wrapped_ep_->GetLocalAddress();
903
+ }
904
+
905
+ void* QueryExtension(absl::string_view id) {
906
+ return wrapped_ep_->QueryExtension(id);
907
+ }
908
+
909
+ void Shutdown() {
910
+ std::unique_ptr<EventEngine::Endpoint> wrapped_ep;
911
+ grpc_core::MutexLock write_lock(frame_protector_.write_mu());
912
+ grpc_core::MutexLock read_lock(frame_protector_.read_mu());
913
+ wrapped_ep = std::move(wrapped_ep_);
914
+ frame_protector_.Shutdown();
915
+ GRPC_TRACE_LOG(secure_endpoint, INFO)
916
+ << "Shutdown for secure endpoint: " << this;
917
+ }
918
+
919
+ std::shared_ptr<TelemetryInfo> GetTelemetryInfo() const {
920
+ return std::make_shared<Impl::TelemetryInfo>(
921
+ wrapped_ep_->GetTelemetryInfo());
922
+ }
923
+
924
+ private:
925
+ bool MaybeFinishReadImmediately() {
926
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("secure_endpoint maybe finish read");
927
+ grpc_core::MutexLock lock(frame_protector_.read_mu());
928
+ // If the read is large, since we got the bytes whilst still calling read,
929
+ // offload the decryption to event engine.
930
+ // That way we can do the decryption off this thread (which is usually
931
+ // under some mutual exclusion device) and publish the bytes using the
932
+ // async callback path.
933
+ // (remember there's at most one outstanding read and write on an
934
+ // EventEngine::Endpoint allowed, so this doesn't risk ordering issues.)
935
+ if (grpc_core::IsSecureEndpointOffloadLargeReadsEnabled() &&
936
+ frame_protector_.source_buffer()->Length() > large_read_threshold_) {
937
+ event_engine_->Run([impl = Ref()]() mutable {
938
+ grpc_core::ExecCtx exec_ctx;
939
+ FinishAsyncRead(std::move(impl), absl::OkStatus());
940
+ });
941
+ return false;
942
+ }
943
+ frame_protector_.TraceOp(
944
+ "Read(Imm)", frame_protector_.source_buffer()->c_slice_buffer());
945
+ auto status = frame_protector_.Unprotect(absl::OkStatus());
946
+ frame_protector_.FinishRead(status.ok());
947
+ if (status.ok()) return true;
948
+ event_engine_->Run([impl = Ref(), status = std::move(status)]() mutable {
949
+ auto on_read = std::move(impl->on_read_);
950
+ impl.reset();
951
+ on_read(status);
952
+ });
953
+ return false;
954
+ }
955
+
956
+ static void FinishAsyncRead(grpc_core::RefCountedPtr<Impl> impl,
957
+ absl::Status status) {
958
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("secure endpoint finish async read");
959
+ {
960
+ grpc_core::MutexLock lock(impl->frame_protector_.read_mu());
961
+ if (status.ok() && impl->wrapped_ep_ == nullptr) {
962
+ status = absl::CancelledError("secure endpoint shutdown");
963
+ }
964
+ status = impl->frame_protector_.Unprotect(std::move(status));
965
+ }
966
+ if (status.ok()) {
967
+ impl->frame_protector_.TraceOp(
968
+ "Read", impl->frame_protector_.source_buffer()->c_slice_buffer());
969
+ }
970
+ auto on_read = std::move(impl->on_read_);
971
+ impl->frame_protector_.FinishRead(status.ok());
972
+ impl.reset();
973
+ on_read(status);
974
+ }
975
+
976
+ std::string WritingString() ABSL_EXCLUSIVE_LOCKS_REQUIRED(write_queue_mu_) {
977
+ if (!writing_.ok()) return writing_.status().ToString();
978
+ return *writing_ ? "true" : "false";
979
+ }
980
+
981
+ static void FailWrites(grpc_core::RefCountedPtr<Impl> impl,
982
+ absl::Status status)
983
+ ABSL_LOCKS_EXCLUDED(frame_protector_.write_mu(), write_queue_mu_) {
984
+ impl->write_queue_mu_.Lock();
985
+ impl->writing_ = status;
986
+ auto on_write = std::move(impl->on_write_);
987
+ impl->write_queue_mu_.Unlock();
988
+ impl.reset();
989
+ if (on_write != nullptr) on_write(status);
990
+ };
991
+
992
+ static void FinishAsyncWrite(grpc_core::RefCountedPtr<Impl> impl) {
993
+ GRPC_LATENT_SEE_ALWAYS_ON_SCOPE("secure endpoint finish async write");
994
+ tsi_result result;
995
+ std::unique_ptr<SliceBuffer> data;
996
+ WriteArgs args;
997
+ // If writes complete immediately we'll loop back to here.
998
+ while (true) {
999
+ {
1000
+ // Check to see if we've written all the bytes.
1001
+ grpc_core::ReleasableMutexLock lock(&impl->write_queue_mu_);
1002
+ if (impl->pending_writes_ == nullptr) {
1003
+ impl->writing_ = false;
1004
+ GRPC_DCHECK(impl->on_write_ == nullptr);
1005
+ lock.Release();
1006
+ return;
1007
+ }
1008
+ // There's more data - grab it under the queue lock.
1009
+ data = std::move(impl->pending_writes_);
1010
+ impl->frame_protector_.TraceOp("data", data->c_slice_buffer());
1011
+ args = std::move(impl->last_write_args_);
1012
+ GRPC_DCHECK(impl->on_write_ != nullptr);
1013
+ }
1014
+ impl->event_engine_->Run(
1015
+ [on_write = std::move(impl->on_write_)]() mutable {
1016
+ on_write(absl::OkStatus());
1017
+ });
1018
+ // Now grab the frame protector write mutex - this is held for some
1019
+ // time (we do the encryption inside of it) - so it's a different
1020
+ // mutex to the queue mutex above.
1021
+ grpc_core::ReleasableMutexLock lock(impl->frame_protector_.write_mu());
1022
+ // If the endpoint closed whilst waiting for this callback, then fail
1023
+ // out the write and we're done.
1024
+ if (impl->wrapped_ep_ == nullptr) {
1025
+ lock.Release();
1026
+ FailWrites(std::move(impl),
1027
+ absl::CancelledError("secure endpoint shutdown"));
1028
+ return;
1029
+ }
1030
+ result = impl->frame_protector_.Protect(data->c_slice_buffer(),
1031
+ args.max_frame_size());
1032
+ if (result != TSI_OK) {
1033
+ lock.Release();
1034
+ // Protection failed... fail the write and we're done.
1035
+ FailWrites(std::move(impl),
1036
+ GRPC_ERROR_CREATE(absl::StrCat(
1037
+ "Wrap failed (", tsi_result_to_string(result), ")")));
1038
+ return;
1039
+ }
1040
+ // Write out the protected bytes - returns true if it finishes
1041
+ // immediately, in which case we'll loop.
1042
+ const bool write_finished_immediately = impl->wrapped_ep_->Write(
1043
+ [impl](absl::Status status) mutable {
1044
+ grpc_core::ExecCtx exec_ctx;
1045
+ // Async completion path: if we completed successfully then loop
1046
+ // back into FinishAsyncWrite to see if there's more writing to
1047
+ // do.
1048
+ if (status.ok()) {
1049
+ FinishAsyncWrite(std::move(impl));
1050
+ return;
1051
+ }
1052
+ // Write failed: push the failure up via the callback if it's
1053
+ // there.
1054
+ FailWrites(std::move(impl), status);
1055
+ },
1056
+ impl->frame_protector_.output_buffer(), std::move(args));
1057
+ if (!write_finished_immediately) break;
1058
+ }
1059
+ }
1060
+
1061
+ grpc_core::Mutex write_queue_mu_;
1062
+ absl::StatusOr<bool> writing_ ABSL_GUARDED_BY(write_queue_mu_) = false;
1063
+ WriteArgs last_write_args_ ABSL_GUARDED_BY(write_queue_mu_);
1064
+ std::unique_ptr<SliceBuffer> pending_writes_
1065
+ ABSL_GUARDED_BY(write_queue_mu_);
1066
+ grpc_core::FrameProtector frame_protector_;
1067
+ absl::AnyInvocable<void(absl::Status)> on_read_;
1068
+ absl::AnyInvocable<void(absl::Status)> on_write_;
1069
+ std::unique_ptr<EventEngine::Endpoint> wrapped_ep_;
1070
+ std::shared_ptr<EventEngine> event_engine_;
1071
+ const size_t large_read_threshold_;
1072
+ const size_t large_write_threshold_;
1073
+ const size_t max_buffered_writes_;
1074
+ };
1075
+
1076
+ grpc_core::RefCountedPtr<Impl> impl_;
1077
+ };
1078
+
1079
+ } // namespace
1080
+ } // namespace grpc_event_engine::experimental
1081
+
569
1082
  grpc_core::OrphanablePtr<grpc_endpoint> grpc_secure_endpoint_create(
570
1083
  struct tsi_frame_protector* protector,
571
1084
  struct tsi_zero_copy_grpc_protector* zero_copy_protector,
572
1085
  grpc_core::OrphanablePtr<grpc_endpoint> to_wrap,
573
- grpc_slice* leftover_slices, const grpc_channel_args* channel_args,
574
- size_t leftover_nslices) {
1086
+ grpc_slice* leftover_slices, size_t leftover_nslices,
1087
+ const grpc_core::ChannelArgs& channel_args) {
1088
+ if (!grpc_core::IsEventEngineSecureEndpointEnabled()) {
1089
+ return grpc_legacy_secure_endpoint_create(
1090
+ protector, zero_copy_protector, std::move(to_wrap), leftover_slices,
1091
+ channel_args.ToC().get(), leftover_nslices);
1092
+ }
1093
+ if (grpc_event_engine::experimental::grpc_get_wrapped_event_engine_endpoint(
1094
+ to_wrap.get()) != nullptr) {
1095
+ std::unique_ptr<grpc_event_engine::experimental::EventEngine::Endpoint>
1096
+ event_engine_endpoint = grpc_event_engine::experimental::
1097
+ grpc_take_wrapped_event_engine_endpoint(to_wrap.release());
1098
+ GRPC_CHECK(event_engine_endpoint != nullptr);
1099
+ if (grpc_core::IsPipelinedReadSecureEndpointEnabled()) {
1100
+ return grpc_pipelined_secure_endpoint_create(
1101
+ protector, zero_copy_protector, std::move(event_engine_endpoint),
1102
+ leftover_slices, channel_args, leftover_nslices);
1103
+ } else {
1104
+ return grpc_core::OrphanablePtr<grpc_endpoint>(
1105
+ grpc_event_engine::experimental::grpc_event_engine_endpoint_create(
1106
+ std::make_unique<grpc_event_engine::experimental::SecureEndpoint>(
1107
+ std::move(event_engine_endpoint), protector,
1108
+ zero_copy_protector, leftover_slices, leftover_nslices,
1109
+ channel_args)));
1110
+ }
1111
+ }
575
1112
  return grpc_core::MakeOrphanable<secure_endpoint>(
576
1113
  &vtable, protector, zero_copy_protector, std::move(to_wrap),
577
- leftover_slices, channel_args, leftover_nslices);
1114
+ leftover_slices, leftover_nslices, channel_args);
578
1115
  }