grpc 1.67.0 → 1.72.0

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 (3236) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +378 -397
  3. data/include/grpc/compression.h +1 -2
  4. data/include/grpc/credentials.h +1 -2
  5. data/include/grpc/event_engine/endpoint_config.h +7 -7
  6. data/include/grpc/event_engine/event_engine.h +56 -14
  7. data/include/grpc/event_engine/extensible.h +2 -2
  8. data/include/grpc/event_engine/internal/memory_allocator_impl.h +4 -4
  9. data/include/grpc/event_engine/memory_allocator.h +3 -4
  10. data/include/grpc/event_engine/memory_request.h +4 -5
  11. data/include/grpc/event_engine/slice.h +3 -4
  12. data/include/grpc/event_engine/slice_buffer.h +6 -7
  13. data/include/grpc/grpc.h +1 -2
  14. data/include/grpc/grpc_audit_logging.h +3 -3
  15. data/include/grpc/grpc_crl_provider.h +4 -4
  16. data/include/grpc/grpc_posix.h +1 -2
  17. data/include/grpc/grpc_security.h +1 -2
  18. data/include/grpc/impl/call.h +2 -2
  19. data/include/grpc/impl/channel_arg_names.h +72 -50
  20. data/include/grpc/impl/grpc_types.h +1 -2
  21. data/include/grpc/impl/slice_type.h +1 -2
  22. data/include/grpc/passive_listener.h +2 -2
  23. data/include/grpc/status.h +1 -1
  24. data/include/grpc/support/alloc.h +1 -2
  25. data/include/grpc/support/atm.h +0 -13
  26. data/include/grpc/support/json.h +17 -18
  27. data/include/grpc/support/log.h +1 -2
  28. data/include/grpc/support/metrics.h +7 -3
  29. data/include/grpc/support/port_platform.h +6 -1
  30. data/include/grpc/support/sync_posix.h +1 -2
  31. data/include/grpc/support/time.h +1 -2
  32. data/include/grpc/support/workaround_list.h +1 -4
  33. data/src/core/call/call_arena_allocator.cc +27 -0
  34. data/src/core/call/call_arena_allocator.h +91 -0
  35. data/src/core/call/call_destination.h +76 -0
  36. data/src/core/call/call_filters.cc +148 -0
  37. data/src/core/call/call_filters.h +1967 -0
  38. data/src/core/call/call_finalization.h +88 -0
  39. data/src/core/call/call_spine.cc +90 -0
  40. data/src/core/call/call_spine.h +644 -0
  41. data/src/core/call/call_state.cc +39 -0
  42. data/src/core/call/call_state.h +1154 -0
  43. data/src/core/call/client_call.cc +458 -0
  44. data/src/core/call/client_call.h +192 -0
  45. data/src/core/call/custom_metadata.h +30 -0
  46. data/src/core/call/interception_chain.cc +155 -0
  47. data/src/core/call/interception_chain.h +282 -0
  48. data/src/core/call/message.cc +44 -0
  49. data/src/core/call/message.h +70 -0
  50. data/src/core/call/metadata.cc +61 -0
  51. data/src/core/call/metadata.h +201 -0
  52. data/src/core/call/metadata_batch.cc +383 -0
  53. data/src/core/call/metadata_batch.h +1668 -0
  54. data/src/core/call/metadata_compression_traits.h +66 -0
  55. data/src/core/call/metadata_info.cc +73 -0
  56. data/src/core/call/metadata_info.h +85 -0
  57. data/src/core/call/parsed_metadata.cc +35 -0
  58. data/src/core/call/parsed_metadata.h +429 -0
  59. data/src/core/call/request_buffer.cc +224 -0
  60. data/src/core/call/request_buffer.h +192 -0
  61. data/src/core/call/security_context.cc +125 -0
  62. data/src/core/call/security_context.h +114 -0
  63. data/src/core/call/server_call.cc +259 -0
  64. data/src/core/call/server_call.h +169 -0
  65. data/src/core/call/simple_slice_based_metadata.h +53 -0
  66. data/src/core/call/status_util.cc +153 -0
  67. data/src/core/call/status_util.h +80 -0
  68. data/src/core/channelz/channel_trace.cc +5 -6
  69. data/src/core/channelz/channel_trace.h +5 -7
  70. data/src/core/channelz/channelz.cc +7 -8
  71. data/src/core/channelz/channelz.h +11 -32
  72. data/src/core/channelz/channelz_registry.cc +6 -14
  73. data/src/core/channelz/channelz_registry.h +4 -5
  74. data/src/core/client_channel/backup_poller.cc +21 -11
  75. data/src/core/client_channel/client_channel.cc +66 -65
  76. data/src/core/client_channel/client_channel.h +10 -7
  77. data/src/core/client_channel/client_channel_args.h +21 -0
  78. data/src/core/client_channel/client_channel_factory.cc +2 -2
  79. data/src/core/client_channel/client_channel_factory.h +1 -2
  80. data/src/core/client_channel/client_channel_filter.cc +91 -175
  81. data/src/core/client_channel/client_channel_filter.h +23 -21
  82. data/src/core/client_channel/client_channel_internal.h +3 -4
  83. data/src/core/client_channel/client_channel_plugin.cc +3 -4
  84. data/src/core/client_channel/client_channel_service_config.cc +3 -4
  85. data/src/core/client_channel/client_channel_service_config.h +9 -11
  86. data/src/core/client_channel/config_selector.h +6 -9
  87. data/src/core/client_channel/connector.h +3 -3
  88. data/src/core/client_channel/direct_channel.cc +6 -6
  89. data/src/core/client_channel/direct_channel.h +1 -1
  90. data/src/core/client_channel/dynamic_filters.cc +10 -9
  91. data/src/core/client_channel/dynamic_filters.h +8 -8
  92. data/src/core/client_channel/global_subchannel_pool.cc +2 -2
  93. data/src/core/client_channel/global_subchannel_pool.h +2 -3
  94. data/src/core/client_channel/lb_metadata.cc +7 -8
  95. data/src/core/client_channel/lb_metadata.h +6 -7
  96. data/src/core/client_channel/load_balanced_call_destination.cc +7 -8
  97. data/src/core/client_channel/load_balanced_call_destination.h +1 -2
  98. data/src/core/client_channel/local_subchannel_pool.cc +2 -3
  99. data/src/core/client_channel/local_subchannel_pool.h +1 -1
  100. data/src/core/client_channel/retry_filter.cc +6 -8
  101. data/src/core/client_channel/retry_filter.h +5 -8
  102. data/src/core/client_channel/retry_filter_legacy_call_data.cc +62 -62
  103. data/src/core/client_channel/retry_filter_legacy_call_data.h +22 -23
  104. data/src/core/client_channel/retry_interceptor.cc +408 -0
  105. data/src/core/client_channel/retry_interceptor.h +157 -0
  106. data/src/core/client_channel/retry_service_config.cc +8 -10
  107. data/src/core/client_channel/retry_service_config.h +20 -9
  108. data/src/core/client_channel/retry_throttle.cc +60 -50
  109. data/src/core/client_channel/retry_throttle.h +16 -11
  110. data/src/core/client_channel/subchannel.cc +62 -99
  111. data/src/core/client_channel/subchannel.h +22 -22
  112. data/src/core/client_channel/subchannel_interface_internal.h +1 -1
  113. data/src/core/client_channel/subchannel_pool_interface.cc +1 -3
  114. data/src/core/client_channel/subchannel_pool_interface.h +2 -3
  115. data/src/core/client_channel/subchannel_stream_client.cc +20 -21
  116. data/src/core/client_channel/subchannel_stream_client.h +13 -15
  117. data/src/core/config/config_vars.cc +152 -0
  118. data/src/core/config/config_vars.h +129 -0
  119. data/src/core/config/config_vars_non_generated.cc +49 -0
  120. data/src/core/config/core_configuration.cc +111 -0
  121. data/src/core/config/core_configuration.h +242 -0
  122. data/src/core/config/load_config.cc +78 -0
  123. data/src/core/config/load_config.h +54 -0
  124. data/src/core/credentials/call/call_credentials.h +157 -0
  125. data/src/core/credentials/call/call_creds_util.cc +97 -0
  126. data/src/core/credentials/call/call_creds_util.h +43 -0
  127. data/src/core/credentials/call/composite/composite_call_credentials.cc +115 -0
  128. data/src/core/credentials/call/composite/composite_call_credentials.h +82 -0
  129. data/src/core/credentials/call/external/aws_external_account_credentials.cc +528 -0
  130. data/src/core/credentials/call/external/aws_external_account_credentials.h +117 -0
  131. data/src/core/credentials/call/external/aws_request_signer.cc +230 -0
  132. data/src/core/credentials/call/external/aws_request_signer.h +72 -0
  133. data/src/core/credentials/call/external/external_account_credentials.cc +641 -0
  134. data/src/core/credentials/call/external/external_account_credentials.h +207 -0
  135. data/src/core/credentials/call/external/file_external_account_credentials.cc +174 -0
  136. data/src/core/credentials/call/external/file_external_account_credentials.h +80 -0
  137. data/src/core/credentials/call/external/url_external_account_credentials.cc +222 -0
  138. data/src/core/credentials/call/external/url_external_account_credentials.h +73 -0
  139. data/src/core/credentials/call/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +196 -0
  140. data/src/core/credentials/call/gcp_service_account_identity/gcp_service_account_identity_credentials.h +90 -0
  141. data/src/core/credentials/call/iam/iam_credentials.cc +78 -0
  142. data/src/core/credentials/call/iam/iam_credentials.h +66 -0
  143. data/src/core/credentials/call/json_util.cc +69 -0
  144. data/src/core/credentials/call/json_util.h +43 -0
  145. data/src/core/credentials/call/jwt/json_token.cc +318 -0
  146. data/src/core/credentials/call/jwt/json_token.h +78 -0
  147. data/src/core/credentials/call/jwt/jwt_credentials.cc +181 -0
  148. data/src/core/credentials/call/jwt/jwt_credentials.h +106 -0
  149. data/src/core/credentials/call/jwt/jwt_verifier.cc +988 -0
  150. data/src/core/credentials/call/jwt/jwt_verifier.h +122 -0
  151. data/src/core/credentials/call/oauth2/oauth2_credentials.cc +654 -0
  152. data/src/core/credentials/call/oauth2/oauth2_credentials.h +197 -0
  153. data/src/core/credentials/call/plugin/plugin_credentials.cc +201 -0
  154. data/src/core/credentials/call/plugin/plugin_credentials.h +123 -0
  155. data/src/core/credentials/call/token_fetcher/token_fetcher_credentials.cc +304 -0
  156. data/src/core/credentials/call/token_fetcher/token_fetcher_credentials.h +181 -0
  157. data/src/core/credentials/transport/alts/alts_credentials.cc +116 -0
  158. data/src/core/credentials/transport/alts/alts_credentials.h +127 -0
  159. data/src/core/credentials/transport/alts/alts_security_connector.cc +303 -0
  160. data/src/core/credentials/transport/alts/alts_security_connector.h +78 -0
  161. data/src/core/credentials/transport/alts/check_gcp_environment.cc +71 -0
  162. data/src/core/credentials/transport/alts/check_gcp_environment.h +57 -0
  163. data/src/core/credentials/transport/alts/check_gcp_environment_linux.cc +67 -0
  164. data/src/core/credentials/transport/alts/check_gcp_environment_no_op.cc +32 -0
  165. data/src/core/credentials/transport/alts/check_gcp_environment_windows.cc +101 -0
  166. data/src/core/credentials/transport/alts/grpc_alts_credentials_client_options.cc +123 -0
  167. data/src/core/credentials/transport/alts/grpc_alts_credentials_options.cc +45 -0
  168. data/src/core/credentials/transport/alts/grpc_alts_credentials_options.h +74 -0
  169. data/src/core/credentials/transport/alts/grpc_alts_credentials_server_options.cc +55 -0
  170. data/src/core/credentials/transport/channel_creds_registry.h +126 -0
  171. data/src/core/credentials/transport/channel_creds_registry_init.cc +245 -0
  172. data/src/core/credentials/transport/composite/composite_channel_credentials.cc +68 -0
  173. data/src/core/credentials/transport/composite/composite_channel_credentials.h +89 -0
  174. data/src/core/credentials/transport/fake/fake_credentials.cc +81 -0
  175. data/src/core/credentials/transport/fake/fake_credentials.h +92 -0
  176. data/src/core/credentials/transport/fake/fake_security_connector.cc +314 -0
  177. data/src/core/credentials/transport/fake/fake_security_connector.h +42 -0
  178. data/src/core/credentials/transport/google_default/credentials_generic.cc +38 -0
  179. data/src/core/credentials/transport/google_default/google_default_credentials.cc +442 -0
  180. data/src/core/credentials/transport/google_default/google_default_credentials.h +101 -0
  181. data/src/core/credentials/transport/insecure/insecure_credentials.cc +71 -0
  182. data/src/core/credentials/transport/insecure/insecure_credentials.h +61 -0
  183. data/src/core/credentials/transport/insecure/insecure_security_connector.cc +118 -0
  184. data/src/core/credentials/transport/insecure/insecure_security_connector.h +102 -0
  185. data/src/core/credentials/transport/local/local_credentials.cc +68 -0
  186. data/src/core/credentials/transport/local/local_credentials.h +77 -0
  187. data/src/core/credentials/transport/local/local_security_connector.cc +306 -0
  188. data/src/core/credentials/transport/local/local_security_connector.h +62 -0
  189. data/src/core/credentials/transport/security_connector.cc +123 -0
  190. data/src/core/credentials/transport/security_connector.h +197 -0
  191. data/src/core/credentials/transport/ssl/ssl_credentials.cc +474 -0
  192. data/src/core/credentials/transport/ssl/ssl_credentials.h +144 -0
  193. data/src/core/credentials/transport/ssl/ssl_security_connector.cc +403 -0
  194. data/src/core/credentials/transport/ssl/ssl_security_connector.h +81 -0
  195. data/src/core/credentials/transport/tls/certificate_provider_factory.h +69 -0
  196. data/src/core/credentials/transport/tls/certificate_provider_registry.cc +50 -0
  197. data/src/core/credentials/transport/tls/certificate_provider_registry.h +75 -0
  198. data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.cc +337 -0
  199. data/src/core/credentials/transport/tls/grpc_tls_certificate_distributor.h +215 -0
  200. data/src/core/credentials/transport/tls/grpc_tls_certificate_match.cc +84 -0
  201. data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.cc +490 -0
  202. data/src/core/credentials/transport/tls/grpc_tls_certificate_provider.h +206 -0
  203. data/src/core/credentials/transport/tls/grpc_tls_certificate_verifier.cc +237 -0
  204. data/src/core/credentials/transport/tls/grpc_tls_certificate_verifier.h +169 -0
  205. data/src/core/credentials/transport/tls/grpc_tls_credentials_options.cc +161 -0
  206. data/src/core/credentials/transport/tls/grpc_tls_credentials_options.h +145 -0
  207. data/src/core/credentials/transport/tls/grpc_tls_crl_provider.cc +257 -0
  208. data/src/core/credentials/transport/tls/grpc_tls_crl_provider.h +129 -0
  209. data/src/core/credentials/transport/tls/load_system_roots.h +35 -0
  210. data/src/core/credentials/transport/tls/load_system_roots_fallback.cc +36 -0
  211. data/src/core/credentials/transport/tls/load_system_roots_supported.cc +165 -0
  212. data/src/core/credentials/transport/tls/load_system_roots_supported.h +44 -0
  213. data/src/core/credentials/transport/tls/load_system_roots_windows.cc +85 -0
  214. data/src/core/credentials/transport/tls/ssl_utils.cc +628 -0
  215. data/src/core/credentials/transport/tls/ssl_utils.h +188 -0
  216. data/src/core/credentials/transport/tls/tls_credentials.cc +170 -0
  217. data/src/core/credentials/transport/tls/tls_credentials.h +75 -0
  218. data/src/core/credentials/transport/tls/tls_security_connector.cc +816 -0
  219. data/src/core/credentials/transport/tls/tls_security_connector.h +285 -0
  220. data/src/core/credentials/transport/tls/tls_utils.cc +127 -0
  221. data/src/core/credentials/transport/tls/tls_utils.h +50 -0
  222. data/src/core/credentials/transport/transport_credentials.cc +158 -0
  223. data/src/core/credentials/transport/transport_credentials.h +182 -0
  224. data/src/core/credentials/transport/xds/xds_credentials.cc +231 -0
  225. data/src/core/credentials/transport/xds/xds_credentials.h +110 -0
  226. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +14 -21
  227. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +7 -8
  228. data/src/core/ext/filters/census/grpc_context.cc +1 -2
  229. data/src/core/ext/filters/channel_idle/idle_filter_state.cc +1 -2
  230. data/src/core/ext/filters/channel_idle/idle_filter_state.h +0 -1
  231. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +25 -24
  232. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +6 -8
  233. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +19 -23
  234. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +7 -9
  235. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +4 -5
  236. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +4 -7
  237. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.cc +56 -25
  238. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.h +35 -20
  239. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.cc +3 -4
  240. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.h +3 -4
  241. data/src/core/ext/filters/http/client/http_client_filter.cc +13 -13
  242. data/src/core/ext/filters/http/client/http_client_filter.h +5 -6
  243. data/src/core/ext/filters/http/client_authority_filter.cc +15 -19
  244. data/src/core/ext/filters/http/client_authority_filter.h +6 -7
  245. data/src/core/ext/filters/http/http_filters_plugin.cc +1 -2
  246. data/src/core/ext/filters/http/message_compress/compression_filter.cc +43 -33
  247. data/src/core/ext/filters/http/message_compress/compression_filter.h +20 -18
  248. data/src/core/ext/filters/http/server/http_server_filter.cc +15 -15
  249. data/src/core/ext/filters/http/server/http_server_filter.h +4 -5
  250. data/src/core/ext/filters/message_size/message_size_filter.cc +27 -33
  251. data/src/core/ext/filters/message_size/message_size_filter.h +22 -25
  252. data/src/core/ext/filters/rbac/rbac_filter.cc +8 -15
  253. data/src/core/ext/filters/rbac/rbac_filter.h +6 -8
  254. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +17 -11
  255. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +2 -4
  256. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +13 -13
  257. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +6 -8
  258. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.cc +3 -4
  259. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +5 -7
  260. data/src/core/ext/transport/chttp2/alpn/alpn.cc +1 -2
  261. data/src/core/ext/transport/chttp2/alpn/alpn.h +1 -2
  262. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +24 -29
  263. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +7 -7
  264. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +765 -189
  265. data/src/core/ext/transport/chttp2/server/chttp2_server.h +195 -15
  266. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +7 -7
  267. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -3
  268. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +4 -6
  269. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -2
  270. data/src/core/ext/transport/chttp2/transport/call_tracer_wrapper.cc +53 -0
  271. data/src/core/ext/transport/chttp2/transport/call_tracer_wrapper.h +70 -0
  272. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +277 -193
  273. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +12 -13
  274. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +4 -5
  275. data/src/core/ext/transport/chttp2/transport/decode_huff.h +4 -4
  276. data/src/core/ext/transport/chttp2/transport/flow_control.cc +4 -6
  277. data/src/core/ext/transport/chttp2/transport/flow_control.h +5 -7
  278. data/src/core/ext/transport/chttp2/transport/frame.cc +109 -70
  279. data/src/core/ext/transport/chttp2/transport/frame.h +52 -7
  280. data/src/core/ext/transport/chttp2/transport/frame_data.cc +19 -13
  281. data/src/core/ext/transport/chttp2/transport/frame_data.h +2 -4
  282. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +11 -13
  283. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -2
  284. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +2 -4
  285. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -2
  286. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +10 -8
  287. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +1 -2
  288. data/src/core/ext/transport/chttp2/transport/frame_security.cc +80 -0
  289. data/src/core/ext/transport/chttp2/transport/frame_security.h +44 -0
  290. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +28 -12
  291. data/src/core/ext/transport/chttp2/transport/frame_settings.h +3 -4
  292. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +21 -3
  293. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +1 -2
  294. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +2 -2
  295. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +10 -11
  296. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +8 -10
  297. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -2
  298. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +4 -5
  299. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +2 -4
  300. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +7 -9
  301. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +38 -39
  302. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +10 -13
  303. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +1 -3
  304. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +4 -6
  305. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +22 -12
  306. data/src/core/ext/transport/chttp2/transport/http2_settings.h +14 -8
  307. data/src/core/ext/transport/chttp2/transport/http2_status.h +52 -0
  308. data/src/core/ext/transport/chttp2/transport/internal.h +58 -112
  309. data/src/core/ext/transport/chttp2/transport/legacy_frame.h +1 -0
  310. data/src/core/ext/transport/chttp2/transport/parsing.cc +90 -42
  311. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +4 -4
  312. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +3 -3
  313. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +4 -4
  314. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +5 -7
  315. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +6 -7
  316. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +4 -6
  317. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +5 -3
  318. data/src/core/ext/transport/chttp2/transport/stream_lists.h +65 -0
  319. data/src/core/ext/transport/chttp2/transport/varint.cc +6 -6
  320. data/src/core/ext/transport/chttp2/transport/varint.h +1 -2
  321. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +2 -2
  322. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +3 -4
  323. data/src/core/ext/transport/chttp2/transport/writing.cc +40 -45
  324. data/src/core/ext/transport/inproc/inproc_transport.cc +8 -11
  325. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +28 -25
  326. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +35 -4
  327. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.c +25 -18
  328. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.h +10 -4
  329. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb.h +101 -69
  330. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.c +52 -46
  331. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.h +9 -4
  332. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb.h +39 -4
  333. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.c +29 -22
  334. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.h +10 -4
  335. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb.h +154 -19
  336. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.c +111 -90
  337. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.h +24 -4
  338. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb.h +10 -4
  339. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.c +8 -4
  340. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.h +7 -4
  341. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb.h +17 -4
  342. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.c +12 -8
  343. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.h +7 -4
  344. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb.h +5 -4
  345. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.c +4 -1
  346. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.h +6 -4
  347. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb.h +11 -10
  348. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.c +8 -5
  349. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.h +6 -4
  350. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb.h +5 -4
  351. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.c +4 -1
  352. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.h +6 -4
  353. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb.h +165 -134
  354. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.c +88 -83
  355. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.h +7 -4
  356. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb.h +7 -4
  357. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.c +7 -4
  358. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.h +6 -4
  359. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb.h +5 -4
  360. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.c +7 -1
  361. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.h +5 -4
  362. data/src/core/ext/upb-gen/envoy/annotations/resource.upb.h +7 -6
  363. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.c +10 -6
  364. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.h +6 -4
  365. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +87 -30
  366. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.c +73 -55
  367. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.h +21 -4
  368. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +397 -220
  369. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +197 -172
  370. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +28 -4
  371. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb.h +58 -31
  372. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.c +31 -26
  373. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.h +8 -4
  374. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +535 -326
  375. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +259 -230
  376. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.h +30 -4
  377. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +9 -4
  378. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +8 -5
  379. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.h +6 -4
  380. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +114 -62
  381. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +44 -41
  382. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.h +6 -4
  383. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +116 -26
  384. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +83 -66
  385. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.h +20 -4
  386. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +73 -33
  387. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +52 -42
  388. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.h +13 -4
  389. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb.h +9 -4
  390. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.c +8 -5
  391. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.h +6 -4
  392. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +405 -190
  393. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +192 -135
  394. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.h +36 -4
  395. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +100 -58
  396. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.c +57 -48
  397. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.h +12 -4
  398. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +7 -4
  399. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.c +7 -4
  400. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.h +6 -4
  401. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb.h +7 -4
  402. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.c +7 -4
  403. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.h +6 -4
  404. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb.h +10 -4
  405. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.c +8 -4
  406. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.h +7 -4
  407. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +128 -63
  408. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +76 -60
  409. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.h +19 -4
  410. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +192 -104
  411. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.c +89 -78
  412. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.h +14 -4
  413. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +12 -4
  414. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +8 -5
  415. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.h +6 -4
  416. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +19 -16
  417. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.c +12 -9
  418. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.h +6 -4
  419. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +304 -118
  420. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +138 -114
  421. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.h +21 -4
  422. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb.h +7 -4
  423. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.c +8 -4
  424. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.h +7 -4
  425. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb.h +12 -4
  426. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.c +9 -5
  427. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.h +7 -4
  428. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_cmsg_headers.upb.h +151 -0
  429. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_cmsg_headers.upb_minitable.c +60 -0
  430. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_cmsg_headers.upb_minitable.h +32 -0
  431. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +235 -22
  432. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.c +71 -19
  433. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.h +13 -4
  434. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +43 -31
  435. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +21 -17
  436. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.h +7 -4
  437. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb.h +9 -4
  438. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.c +8 -5
  439. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.h +6 -4
  440. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +45 -16
  441. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +25 -19
  442. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.h +9 -4
  443. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +89 -45
  444. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.c +57 -48
  445. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.h +12 -4
  446. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb.h +68 -28
  447. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.c +36 -28
  448. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.h +11 -4
  449. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb.h +7 -4
  450. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.c +7 -4
  451. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.h +6 -4
  452. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +222 -143
  453. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.c +99 -87
  454. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.h +15 -4
  455. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +127 -164
  456. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.c +67 -79
  457. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.h +11 -5
  458. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb.h +112 -4
  459. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.c +41 -16
  460. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.h +6 -4
  461. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb.h +11 -4
  462. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.c +10 -6
  463. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.h +7 -4
  464. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb.h +15 -10
  465. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.c +12 -9
  466. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.h +6 -4
  467. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +66 -37
  468. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.c +48 -38
  469. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.h +13 -4
  470. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +53 -5
  471. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.c +41 -29
  472. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.h +15 -4
  473. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +258 -16
  474. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.c +108 -65
  475. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.h +18 -4
  476. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +102 -56
  477. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +34 -29
  478. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.h +8 -4
  479. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +1289 -615
  480. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +582 -465
  481. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.h +67 -4
  482. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +27 -17
  483. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.c +17 -12
  484. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.h +8 -4
  485. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +72 -7
  486. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +61 -47
  487. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.h +17 -4
  488. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb.h +9 -4
  489. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.c +11 -7
  490. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.h +7 -4
  491. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +7 -4
  492. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +7 -4
  493. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.h +6 -4
  494. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +9 -4
  495. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.c +11 -7
  496. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.h +7 -4
  497. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb.h +7 -4
  498. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.c +7 -4
  499. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.h +6 -4
  500. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +23 -11
  501. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +13 -10
  502. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.h +6 -4
  503. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb.h +7 -4
  504. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.c +7 -4
  505. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.h +6 -4
  506. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +26 -19
  507. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.c +19 -15
  508. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.h +7 -4
  509. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb.h +5 -6
  510. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.c +3 -2
  511. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.h +5 -5
  512. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb.h +20 -11
  513. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.c +16 -12
  514. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.h +7 -4
  515. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb.h +23 -20
  516. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.c +17 -14
  517. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.h +6 -4
  518. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +402 -310
  519. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +168 -150
  520. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.h +21 -4
  521. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +5 -4
  522. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.c +4 -1
  523. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.h +6 -4
  524. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +17 -4
  525. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.c +18 -11
  526. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.h +10 -4
  527. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +85 -65
  528. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.c +45 -40
  529. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.h +8 -4
  530. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb.h +36 -23
  531. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.c +23 -17
  532. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.h +9 -4
  533. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +40 -29
  534. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.c +23 -19
  535. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.h +7 -4
  536. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +55 -38
  537. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +23 -19
  538. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.h +7 -4
  539. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +12 -7
  540. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +13 -9
  541. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.h +7 -4
  542. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +488 -295
  543. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +240 -216
  544. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.h +26 -4
  545. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +7 -4
  546. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.c +7 -4
  547. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.h +6 -4
  548. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +77 -4
  549. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb_minitable.c +25 -11
  550. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb_minitable.h +6 -4
  551. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +24 -7
  552. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.c +25 -18
  553. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.h +10 -4
  554. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +5 -4
  555. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.c +4 -1
  556. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.h +6 -4
  557. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +38 -27
  558. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.c +19 -16
  559. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.h +6 -4
  560. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +7 -4
  561. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.c +7 -4
  562. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.h +6 -4
  563. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb.h +105 -0
  564. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.c +51 -0
  565. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.h +32 -0
  566. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +5 -4
  567. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.c +3 -1
  568. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.h +5 -4
  569. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +143 -88
  570. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +70 -60
  571. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.h +13 -4
  572. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +17 -4
  573. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.c +18 -13
  574. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.h +8 -4
  575. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +229 -78
  576. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +98 -80
  577. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.h +12 -4
  578. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +49 -11
  579. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.c +17 -11
  580. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.h +7 -4
  581. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +66 -28
  582. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.c +37 -31
  583. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.h +9 -4
  584. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb.h +5 -4
  585. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.c +4 -1
  586. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.h +6 -4
  587. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +440 -127
  588. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.c +137 -96
  589. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.h +21 -4
  590. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb.h +20 -10
  591. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.c +14 -10
  592. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.h +7 -4
  593. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +107 -65
  594. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +58 -51
  595. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.h +10 -4
  596. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb.h +14 -11
  597. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.c +10 -7
  598. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.h +6 -4
  599. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +14 -4
  600. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.c +14 -8
  601. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.h +9 -4
  602. data/src/core/ext/upb-gen/envoy/type/matcher/v3/address.upb.h +142 -0
  603. data/src/core/ext/upb-gen/envoy/type/matcher/v3/address.upb_minitable.c +55 -0
  604. data/src/core/ext/upb-gen/envoy/type/matcher/v3/address.upb_minitable.h +32 -0
  605. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +40 -4
  606. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.c +13 -7
  607. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.h +6 -4
  608. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb.h +5 -4
  609. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.c +8 -1
  610. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.h +10 -4
  611. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +18 -10
  612. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.c +11 -7
  613. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.h +7 -4
  614. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb.h +12 -4
  615. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.c +8 -5
  616. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.h +6 -4
  617. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +7 -4
  618. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.c +7 -4
  619. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.h +6 -4
  620. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +7 -4
  621. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.c +7 -4
  622. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.h +6 -4
  623. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +18 -11
  624. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.c +18 -13
  625. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.h +8 -4
  626. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb.h +5 -4
  627. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.c +5 -1
  628. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.h +7 -4
  629. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +14 -4
  630. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.c +12 -8
  631. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.h +7 -4
  632. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +12 -4
  633. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.c +9 -5
  634. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.h +7 -4
  635. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +22 -4
  636. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +20 -14
  637. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.h +9 -4
  638. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +18 -4
  639. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.c +19 -10
  640. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.h +12 -4
  641. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +28 -15
  642. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.c +22 -15
  643. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.h +10 -4
  644. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +9 -4
  645. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.c +10 -5
  646. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.h +8 -4
  647. data/src/core/ext/upb-gen/envoy/type/v3/http.upb.h +5 -4
  648. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.c +3 -1
  649. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.h +5 -4
  650. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb.h +5 -4
  651. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.c +4 -1
  652. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.h +6 -4
  653. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb.h +5 -4
  654. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.c +5 -1
  655. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.h +7 -4
  656. data/src/core/ext/upb-gen/envoy/type/v3/range.upb.h +5 -4
  657. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.c +6 -1
  658. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.h +8 -4
  659. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +9 -4
  660. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.c +9 -5
  661. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.h +7 -4
  662. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb.h +5 -4
  663. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.c +3 -1
  664. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.h +5 -4
  665. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb.h +5 -4
  666. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.c +4 -1
  667. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.h +6 -4
  668. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb.h +9 -4
  669. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.c +8 -5
  670. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.h +6 -4
  671. data/src/core/ext/upb-gen/google/api/annotations.upb.h +7 -6
  672. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.c +5 -2
  673. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.h +5 -4
  674. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +168 -89
  675. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +89 -74
  676. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.h +18 -4
  677. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +162 -84
  678. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +98 -80
  679. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.h +21 -4
  680. data/src/core/ext/upb-gen/google/api/http.upb.h +69 -55
  681. data/src/core/ext/upb-gen/google/api/http.upb_minitable.c +35 -30
  682. data/src/core/ext/upb-gen/google/api/http.upb_minitable.h +8 -4
  683. data/src/core/ext/upb-gen/google/api/httpbody.upb.h +10 -4
  684. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.c +7 -4
  685. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.h +6 -4
  686. data/src/core/ext/upb-gen/google/protobuf/any.upb.h +6 -4
  687. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.c +4 -1
  688. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.h +6 -4
  689. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +529 -305
  690. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +337 -290
  691. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +56 -21
  692. data/src/core/ext/upb-gen/google/protobuf/duration.upb.h +6 -4
  693. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.c +4 -1
  694. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.h +6 -4
  695. data/src/core/ext/upb-gen/google/protobuf/empty.upb.h +6 -4
  696. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.c +4 -1
  697. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.h +6 -4
  698. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +34 -13
  699. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.c +20 -14
  700. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.h +9 -4
  701. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb.h +6 -4
  702. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.c +4 -1
  703. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.h +6 -4
  704. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb.h +6 -4
  705. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.c +12 -1
  706. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.h +14 -4
  707. data/src/core/ext/upb-gen/google/rpc/status.upb.h +10 -4
  708. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.c +7 -4
  709. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.h +6 -4
  710. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +21 -13
  711. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.c +9 -5
  712. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.h +7 -4
  713. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +170 -114
  714. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +76 -62
  715. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.h +17 -4
  716. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +10 -4
  717. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +9 -5
  718. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.h +7 -4
  719. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb.h +6 -4
  720. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.c +5 -1
  721. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.h +7 -4
  722. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +35 -10
  723. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.c +35 -24
  724. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.h +14 -4
  725. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +32 -25
  726. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.c +12 -7
  727. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.h +8 -4
  728. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +125 -74
  729. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.c +50 -39
  730. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.h +14 -4
  731. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb.h +15 -14
  732. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.c +22 -12
  733. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.h +8 -4
  734. data/src/core/ext/upb-gen/udpa/annotations/security.upb.h +7 -6
  735. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.c +10 -6
  736. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.h +6 -4
  737. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb.h +5 -4
  738. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.c +4 -1
  739. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.h +5 -4
  740. data/src/core/ext/upb-gen/udpa/annotations/status.upb.h +7 -6
  741. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.c +10 -6
  742. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.h +6 -4
  743. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb.h +7 -6
  744. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.c +10 -6
  745. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.h +6 -4
  746. data/src/core/ext/upb-gen/validate/validate.upb.h +457 -374
  747. data/src/core/ext/upb-gen/validate/validate.upb_minitable.c +233 -204
  748. data/src/core/ext/upb-gen/validate/validate.upb_minitable.h +29 -5
  749. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb.h +15 -14
  750. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.c +22 -12
  751. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.h +8 -4
  752. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb.h +7 -6
  753. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.c +10 -6
  754. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.h +6 -4
  755. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb.h +5 -4
  756. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.c +4 -1
  757. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.h +5 -4
  758. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb.h +11 -10
  759. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.c +20 -11
  760. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.h +9 -4
  761. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb.h +7 -6
  762. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.c +10 -6
  763. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.h +6 -4
  764. data/src/core/ext/upb-gen/xds/core/v3/authority.upb.h +5 -4
  765. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.c +4 -1
  766. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.h +6 -4
  767. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb.h +7 -4
  768. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.c +7 -4
  769. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.h +6 -4
  770. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +11 -4
  771. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.c +12 -8
  772. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.h +7 -4
  773. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb.h +19 -13
  774. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.c +8 -4
  775. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.h +7 -4
  776. data/src/core/ext/upb-gen/xds/core/v3/extension.upb.h +7 -4
  777. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.c +7 -4
  778. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.h +6 -4
  779. data/src/core/ext/upb-gen/xds/core/v3/resource.upb.h +16 -11
  780. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.c +11 -8
  781. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.h +6 -4
  782. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +26 -16
  783. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.c +14 -10
  784. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.h +7 -4
  785. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb.h +7 -4
  786. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.c +7 -4
  787. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.h +6 -4
  788. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +47 -31
  789. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.c +12 -6
  790. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.h +9 -4
  791. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb.h +7 -4
  792. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.c +7 -4
  793. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.h +6 -4
  794. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +14 -11
  795. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +10 -7
  796. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.h +6 -4
  797. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb.h +12 -4
  798. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.c +11 -7
  799. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.h +7 -4
  800. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb.h +5 -4
  801. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.c +4 -1
  802. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.h +6 -4
  803. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb.h +20 -7
  804. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.c +13 -9
  805. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.h +7 -4
  806. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +83 -26
  807. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.c +58 -46
  808. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.h +15 -4
  809. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb.h +41 -4
  810. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.c +30 -22
  811. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.h +11 -4
  812. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +7 -4
  813. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.c +8 -4
  814. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.h +7 -4
  815. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +12 -4
  816. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.c +11 -7
  817. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.h +7 -4
  818. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +13 -4
  819. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.c +13 -9
  820. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.h +7 -4
  821. data/src/core/ext/upb-gen/xds/type/v3/range.upb.h +6 -4
  822. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.c +6 -1
  823. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.h +8 -4
  824. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb.h +7 -4
  825. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.c +7 -4
  826. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.h +6 -4
  827. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.c +2 -1
  828. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.h +5 -4
  829. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.c +2 -1
  830. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.h +5 -4
  831. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.c +2 -1
  832. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.h +5 -4
  833. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.c +13 -11
  834. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.h +5 -4
  835. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.c +2 -1
  836. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.h +5 -4
  837. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.c +2 -1
  838. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.h +5 -4
  839. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.c +2 -1
  840. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.h +5 -4
  841. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.c +2 -1
  842. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.h +5 -4
  843. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.c +2 -1
  844. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.h +5 -4
  845. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +8 -5
  846. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.h +5 -4
  847. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.c +2 -1
  848. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.h +5 -4
  849. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.c +2 -1
  850. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.h +5 -4
  851. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.c +2 -1
  852. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.h +5 -4
  853. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +2 -1
  854. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.h +5 -4
  855. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +2 -1
  856. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +5 -4
  857. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +2 -1
  858. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +5 -4
  859. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +420 -414
  860. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +5 -4
  861. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +2 -1
  862. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.h +5 -4
  863. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +2 -1
  864. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.h +5 -4
  865. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +2 -1
  866. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.h +5 -4
  867. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +2 -1
  868. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.h +5 -4
  869. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.c +2 -1
  870. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.h +5 -4
  871. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +163 -154
  872. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +10 -4
  873. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +2 -1
  874. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.h +5 -4
  875. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.c +2 -1
  876. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.h +5 -4
  877. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.c +2 -1
  878. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.h +5 -4
  879. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.c +2 -1
  880. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.h +5 -4
  881. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +2 -1
  882. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.h +5 -4
  883. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +2 -1
  884. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.h +5 -4
  885. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +2 -1
  886. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +5 -4
  887. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +2 -1
  888. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.h +5 -4
  889. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +272 -262
  890. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.h +5 -4
  891. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.c +2 -1
  892. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.h +5 -4
  893. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.c +2 -1
  894. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.h +5 -4
  895. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.c +46 -0
  896. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.h +33 -0
  897. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.c +31 -20
  898. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.h +20 -4
  899. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +2 -1
  900. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +5 -4
  901. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.c +2 -1
  902. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.h +5 -4
  903. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +2 -1
  904. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.h +5 -4
  905. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +2 -1
  906. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +5 -4
  907. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +2 -1
  908. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +5 -4
  909. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.c +2 -1
  910. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.h +5 -4
  911. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +2 -1
  912. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.h +5 -4
  913. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.c +60 -66
  914. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.h +5 -9
  915. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +75 -64
  916. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.h +5 -4
  917. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.c +2 -1
  918. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.h +5 -4
  919. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.c +2 -1
  920. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.h +5 -4
  921. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.c +2 -1
  922. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.h +5 -4
  923. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.c +51 -49
  924. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.h +5 -4
  925. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +119 -101
  926. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.h +10 -4
  927. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +2 -1
  928. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.h +5 -4
  929. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +919 -899
  930. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.h +15 -4
  931. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.c +2 -1
  932. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.h +5 -4
  933. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +2 -1
  934. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.h +5 -4
  935. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +2 -1
  936. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +5 -4
  937. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +2 -1
  938. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.h +5 -4
  939. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.c +2 -1
  940. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.h +5 -4
  941. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.c +2 -1
  942. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.h +5 -4
  943. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +2 -1
  944. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.h +5 -4
  945. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.c +2 -1
  946. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.h +5 -4
  947. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.c +2 -1
  948. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.h +5 -4
  949. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.c +17 -19
  950. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.h +5 -4
  951. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.c +2 -1
  952. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.h +5 -4
  953. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +2 -1
  954. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.h +5 -4
  955. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +2 -1
  956. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.h +5 -4
  957. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +2 -1
  958. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +5 -4
  959. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +2 -1
  960. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +5 -4
  961. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +2 -1
  962. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +5 -4
  963. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +2 -1
  964. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +5 -4
  965. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +35 -34
  966. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +5 -4
  967. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +2 -1
  968. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.h +5 -4
  969. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +2 -1
  970. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +5 -4
  971. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +462 -458
  972. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -4
  973. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +2 -1
  974. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +5 -4
  975. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.c +50 -0
  976. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.h +33 -0
  977. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +2 -1
  978. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +5 -4
  979. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +97 -96
  980. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -4
  981. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +2 -1
  982. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +5 -4
  983. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +204 -192
  984. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +5 -4
  985. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +21 -18
  986. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +5 -4
  987. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.c +2 -1
  988. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.h +5 -4
  989. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.c +2 -1
  990. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.h +5 -4
  991. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.c +150 -136
  992. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.h +10 -4
  993. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.c +2 -1
  994. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.h +5 -4
  995. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +25 -23
  996. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.h +5 -4
  997. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.c +2 -1
  998. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.h +5 -4
  999. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.c +2 -1
  1000. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.h +5 -4
  1001. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.c +41 -0
  1002. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.h +33 -0
  1003. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.c +28 -20
  1004. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.h +5 -4
  1005. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  1006. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.h +5 -4
  1007. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.c +2 -1
  1008. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.h +5 -4
  1009. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.c +2 -1
  1010. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.h +5 -4
  1011. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.c +2 -1
  1012. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.h +5 -4
  1013. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.c +2 -1
  1014. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.h +5 -4
  1015. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.c +2 -1
  1016. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.h +5 -4
  1017. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.c +2 -1
  1018. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.h +5 -4
  1019. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +2 -1
  1020. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.h +5 -4
  1021. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.c +2 -1
  1022. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.h +5 -4
  1023. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +2 -1
  1024. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +5 -4
  1025. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.c +2 -1
  1026. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.h +5 -4
  1027. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.c +2 -1
  1028. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.h +5 -4
  1029. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.c +2 -1
  1030. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.h +5 -4
  1031. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.c +2 -1
  1032. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.h +5 -4
  1033. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.c +2 -1
  1034. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.h +5 -4
  1035. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.c +2 -1
  1036. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.h +5 -4
  1037. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.c +2 -1
  1038. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.h +5 -4
  1039. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.c +2 -1
  1040. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.h +5 -4
  1041. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.c +2 -1
  1042. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.h +5 -4
  1043. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.c +2 -1
  1044. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.h +5 -4
  1045. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.c +2 -1
  1046. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.h +5 -4
  1047. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.c +2 -1
  1048. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.h +5 -4
  1049. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +2 -1
  1050. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.h +5 -4
  1051. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +2 -1
  1052. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +5 -4
  1053. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.c +2 -1
  1054. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.h +5 -4
  1055. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.c +2 -1
  1056. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.h +5 -4
  1057. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.c +2 -1
  1058. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.h +5 -4
  1059. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +497 -484
  1060. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +5 -4
  1061. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.c +2 -1
  1062. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.h +5 -4
  1063. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.c +2 -1
  1064. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.h +5 -4
  1065. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.c +2 -1
  1066. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.h +5 -4
  1067. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.c +2 -1
  1068. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.h +5 -4
  1069. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.c +2 -1
  1070. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.h +5 -4
  1071. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.c +2 -1
  1072. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.h +5 -4
  1073. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +2 -1
  1074. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +5 -4
  1075. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.c +2 -1
  1076. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.h +5 -4
  1077. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.c +2 -1
  1078. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.h +5 -4
  1079. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.c +2 -1
  1080. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.h +5 -4
  1081. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.c +2 -1
  1082. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.h +5 -4
  1083. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.c +2 -1
  1084. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.h +5 -4
  1085. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.c +2 -1
  1086. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.h +5 -4
  1087. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.c +2 -1
  1088. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.h +5 -4
  1089. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.c +2 -1
  1090. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.h +5 -4
  1091. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.c +2 -1
  1092. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.h +5 -4
  1093. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.c +2 -1
  1094. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.h +5 -4
  1095. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.c +2 -1
  1096. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.h +5 -4
  1097. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.c +2 -1
  1098. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.h +5 -4
  1099. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.c +2 -1
  1100. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.h +5 -4
  1101. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.c +2 -1
  1102. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.h +5 -4
  1103. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.c +2 -1
  1104. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.h +5 -4
  1105. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.c +2 -1
  1106. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.h +5 -4
  1107. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.c +2 -1
  1108. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.h +5 -4
  1109. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.c +2 -1
  1110. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.h +5 -4
  1111. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.c +2 -1
  1112. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.h +5 -4
  1113. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +2 -1
  1114. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.h +5 -4
  1115. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.c +2 -1
  1116. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.h +5 -4
  1117. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  1118. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.h +5 -4
  1119. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.c +2 -1
  1120. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.h +5 -4
  1121. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.c +2 -1
  1122. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.h +5 -4
  1123. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.c +2 -1
  1124. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.h +5 -4
  1125. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.c +2 -1
  1126. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.h +5 -4
  1127. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.c +2 -1
  1128. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.h +5 -4
  1129. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.c +2 -1
  1130. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.h +5 -4
  1131. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.c +2 -1
  1132. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.h +5 -4
  1133. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.c +2 -1
  1134. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.h +5 -4
  1135. data/src/core/filter/auth/auth_filters.h +233 -0
  1136. data/src/core/filter/auth/client_auth_filter.cc +310 -0
  1137. data/src/core/filter/auth/server_auth_filter.cc +208 -0
  1138. data/src/core/filter/blackboard.cc +33 -0
  1139. data/src/core/filter/blackboard.h +70 -0
  1140. data/src/core/filter/filter_args.h +112 -0
  1141. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.cc +4 -5
  1142. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.h +1 -1
  1143. data/src/core/handshaker/handshaker.cc +8 -22
  1144. data/src/core/handshaker/handshaker.h +8 -10
  1145. data/src/core/handshaker/handshaker_registry.cc +1 -2
  1146. data/src/core/handshaker/handshaker_registry.h +2 -2
  1147. data/src/core/handshaker/http_connect/http_connect_handshaker.cc +17 -16
  1148. data/src/core/handshaker/http_connect/http_connect_handshaker.h +1 -1
  1149. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +38 -41
  1150. data/src/core/handshaker/http_connect/http_proxy_mapper.h +7 -8
  1151. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.cc +57 -0
  1152. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.h +46 -0
  1153. data/src/core/handshaker/proxy_mapper.h +6 -7
  1154. data/src/core/handshaker/proxy_mapper_registry.cc +7 -8
  1155. data/src/core/handshaker/proxy_mapper_registry.h +6 -7
  1156. data/src/core/handshaker/security/secure_endpoint.cc +14 -16
  1157. data/src/core/handshaker/security/secure_endpoint.h +2 -3
  1158. data/src/core/handshaker/security/security_handshaker.cc +19 -27
  1159. data/src/core/handshaker/security/security_handshaker.h +4 -5
  1160. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +16 -15
  1161. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.h +1 -1
  1162. data/src/core/lib/address_utils/parse_address.cc +3 -4
  1163. data/src/core/lib/address_utils/parse_address.h +2 -4
  1164. data/src/core/lib/address_utils/sockaddr_utils.cc +4 -6
  1165. data/src/core/lib/address_utils/sockaddr_utils.h +1 -3
  1166. data/src/core/lib/channel/channel_args.cc +17 -19
  1167. data/src/core/lib/channel/channel_args.h +68 -51
  1168. data/src/core/lib/channel/channel_args_preconditioning.cc +2 -2
  1169. data/src/core/lib/channel/channel_args_preconditioning.h +4 -4
  1170. data/src/core/lib/channel/channel_stack.cc +5 -4
  1171. data/src/core/lib/channel/channel_stack.h +18 -19
  1172. data/src/core/lib/channel/channel_stack_builder.cc +2 -2
  1173. data/src/core/lib/channel/channel_stack_builder.h +3 -4
  1174. data/src/core/lib/channel/channel_stack_builder_impl.cc +6 -8
  1175. data/src/core/lib/channel/channel_stack_builder_impl.h +15 -3
  1176. data/src/core/lib/channel/connected_channel.cc +12 -14
  1177. data/src/core/lib/channel/promise_based_filter.cc +42 -33
  1178. data/src/core/lib/channel/promise_based_filter.h +101 -147
  1179. data/src/core/lib/compression/compression.cc +5 -6
  1180. data/src/core/lib/compression/compression_internal.cc +14 -16
  1181. data/src/core/lib/compression/compression_internal.h +6 -8
  1182. data/src/core/lib/compression/message_compress.cc +3 -6
  1183. data/src/core/lib/debug/trace.cc +5 -6
  1184. data/src/core/lib/debug/trace_flags.cc +6 -6
  1185. data/src/core/lib/debug/trace_flags.h +2 -2
  1186. data/src/core/lib/debug/trace_impl.h +2 -2
  1187. data/src/core/lib/event_engine/ares_resolver.cc +20 -26
  1188. data/src/core/lib/event_engine/ares_resolver.h +13 -20
  1189. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +4 -8
  1190. data/src/core/lib/event_engine/cf_engine/cf_engine.h +3 -5
  1191. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +7 -9
  1192. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +6 -10
  1193. data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +2 -4
  1194. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +11 -13
  1195. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +5 -9
  1196. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +7 -10
  1197. data/src/core/lib/event_engine/channel_args_endpoint_config.h +7 -9
  1198. data/src/core/lib/event_engine/common_closures.h +5 -7
  1199. data/src/core/lib/event_engine/default_event_engine.cc +69 -41
  1200. data/src/core/lib/event_engine/default_event_engine.h +27 -36
  1201. data/src/core/lib/event_engine/default_event_engine_factory.cc +14 -20
  1202. data/src/core/lib/event_engine/default_event_engine_factory.h +5 -7
  1203. data/src/core/lib/event_engine/event_engine.cc +4 -6
  1204. data/src/core/lib/event_engine/extensions/can_track_errors.h +4 -6
  1205. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +3 -6
  1206. data/src/core/lib/event_engine/extensions/iomgr_compatible.h +39 -0
  1207. data/src/core/lib/event_engine/extensions/supports_fd.h +22 -7
  1208. data/src/core/lib/event_engine/extensions/supports_win_sockets.h +48 -0
  1209. data/src/core/lib/event_engine/extensions/tcp_trace.h +3 -6
  1210. data/src/core/lib/event_engine/forkable.cc +5 -7
  1211. data/src/core/lib/event_engine/forkable.h +4 -6
  1212. data/src/core/lib/event_engine/grpc_polled_fd.h +5 -8
  1213. data/src/core/lib/event_engine/handle_containers.h +4 -7
  1214. data/src/core/lib/event_engine/memory_allocator_factory.h +5 -8
  1215. data/src/core/lib/event_engine/nameser.h +1 -1
  1216. data/src/core/lib/event_engine/poller.h +4 -6
  1217. data/src/core/lib/event_engine/posix.h +2 -4
  1218. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +14 -62
  1219. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +6 -9
  1220. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +21 -71
  1221. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +6 -9
  1222. data/src/core/lib/event_engine/posix_engine/event_poller.h +5 -8
  1223. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +6 -9
  1224. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +4 -6
  1225. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +6 -10
  1226. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +4 -7
  1227. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +3 -6
  1228. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +7 -10
  1229. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +4 -7
  1230. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +4 -7
  1231. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +4 -7
  1232. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +35 -29
  1233. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +10 -13
  1234. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +54 -37
  1235. data/src/core/lib/event_engine/posix_engine/posix_engine.h +18 -20
  1236. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +5 -7
  1237. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +10 -14
  1238. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +14 -15
  1239. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +32 -10
  1240. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +7 -6
  1241. data/src/core/lib/event_engine/posix_engine/set_socket_dualstack.cc +64 -0
  1242. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +13 -28
  1243. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +9 -12
  1244. data/src/core/lib/event_engine/posix_engine/timer.cc +8 -10
  1245. data/src/core/lib/event_engine/posix_engine/timer.h +9 -13
  1246. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +4 -7
  1247. data/src/core/lib/event_engine/posix_engine/timer_heap.h +4 -6
  1248. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +8 -11
  1249. data/src/core/lib/event_engine/posix_engine/timer_manager.h +9 -13
  1250. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +9 -15
  1251. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +27 -30
  1252. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +7 -10
  1253. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +4 -7
  1254. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +16 -11
  1255. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +4 -7
  1256. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +4 -6
  1257. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +4 -7
  1258. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +4 -6
  1259. data/src/core/lib/event_engine/query_extensions.h +4 -6
  1260. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +5 -9
  1261. data/src/core/lib/event_engine/resolved_address.cc +7 -8
  1262. data/src/core/lib/event_engine/resolved_address_internal.h +2 -4
  1263. data/src/core/lib/event_engine/shim.cc +11 -20
  1264. data/src/core/lib/event_engine/shim.h +13 -4
  1265. data/src/core/lib/event_engine/slice.cc +5 -9
  1266. data/src/core/lib/event_engine/slice_buffer.cc +3 -6
  1267. data/src/core/lib/event_engine/tcp_socket_utils.cc +9 -18
  1268. data/src/core/lib/event_engine/tcp_socket_utils.h +8 -10
  1269. data/src/core/lib/event_engine/thread_local.cc +2 -4
  1270. data/src/core/lib/event_engine/thread_local.h +2 -4
  1271. data/src/core/lib/event_engine/thread_pool/thread_count.cc +4 -8
  1272. data/src/core/lib/event_engine/thread_pool/thread_count.h +9 -24
  1273. data/src/core/lib/event_engine/thread_pool/thread_pool.h +4 -8
  1274. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +4 -7
  1275. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +27 -23
  1276. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +11 -14
  1277. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +7 -9
  1278. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +7 -9
  1279. data/src/core/lib/event_engine/time_util.cc +4 -6
  1280. data/src/core/lib/event_engine/time_util.h +3 -6
  1281. data/src/core/lib/event_engine/utils.cc +21 -9
  1282. data/src/core/lib/event_engine/utils.h +12 -8
  1283. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +7 -12
  1284. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.h +6 -10
  1285. data/src/core/lib/event_engine/windows/iocp.cc +6 -9
  1286. data/src/core/lib/event_engine/windows/iocp.h +3 -6
  1287. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.cc +6 -10
  1288. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.h +2 -4
  1289. data/src/core/lib/event_engine/windows/win_socket.cc +17 -9
  1290. data/src/core/lib/event_engine/windows/win_socket.h +9 -9
  1291. data/src/core/lib/event_engine/windows/windows_endpoint.cc +35 -29
  1292. data/src/core/lib/event_engine/windows/windows_endpoint.h +4 -6
  1293. data/src/core/lib/event_engine/windows/windows_engine.cc +55 -15
  1294. data/src/core/lib/event_engine/windows/windows_engine.h +18 -15
  1295. data/src/core/lib/event_engine/windows/windows_listener.cc +9 -13
  1296. data/src/core/lib/event_engine/windows/windows_listener.h +15 -13
  1297. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +5 -7
  1298. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +5 -9
  1299. data/src/core/lib/event_engine/work_queue/work_queue.h +4 -7
  1300. data/src/core/lib/experiments/config.cc +9 -12
  1301. data/src/core/lib/experiments/config.h +1 -2
  1302. data/src/core/lib/experiments/experiments.cc +442 -174
  1303. data/src/core/lib/experiments/experiments.h +187 -86
  1304. data/src/core/lib/iomgr/buffer_list.cc +4 -5
  1305. data/src/core/lib/iomgr/buffer_list.h +23 -23
  1306. data/src/core/lib/iomgr/call_combiner.cc +2 -4
  1307. data/src/core/lib/iomgr/call_combiner.h +6 -8
  1308. data/src/core/lib/iomgr/cfstream_handle.cc +2 -6
  1309. data/src/core/lib/iomgr/cfstream_handle.h +1 -1
  1310. data/src/core/lib/iomgr/closure.cc +2 -2
  1311. data/src/core/lib/iomgr/closure.h +7 -10
  1312. data/src/core/lib/iomgr/combiner.cc +4 -7
  1313. data/src/core/lib/iomgr/combiner.h +2 -3
  1314. data/src/core/lib/iomgr/endpoint.h +1 -2
  1315. data/src/core/lib/iomgr/endpoint_cfstream.cc +2 -4
  1316. data/src/core/lib/iomgr/endpoint_pair_posix.cc +45 -20
  1317. data/src/core/lib/iomgr/endpoint_pair_windows.cc +44 -10
  1318. data/src/core/lib/iomgr/error.cc +34 -52
  1319. data/src/core/lib/iomgr/error.h +6 -8
  1320. data/src/core/lib/iomgr/error_cfstream.cc +1 -3
  1321. data/src/core/lib/iomgr/ev_apple.cc +3 -4
  1322. data/src/core/lib/iomgr/ev_epoll1_linux.cc +20 -10
  1323. data/src/core/lib/iomgr/ev_poll_posix.cc +16 -5
  1324. data/src/core/lib/iomgr/ev_posix.cc +4 -6
  1325. data/src/core/lib/iomgr/ev_posix.h +1 -2
  1326. data/src/core/lib/iomgr/event_engine_shims/closure.cc +3 -5
  1327. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -2
  1328. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +11 -14
  1329. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +2 -2
  1330. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +2 -4
  1331. data/src/core/lib/iomgr/exec_ctx.cc +5 -12
  1332. data/src/core/lib/iomgr/exec_ctx.h +7 -140
  1333. data/src/core/lib/iomgr/executor.cc +6 -19
  1334. data/src/core/lib/iomgr/executor.h +1 -1
  1335. data/src/core/lib/iomgr/fork_posix.cc +5 -7
  1336. data/src/core/lib/iomgr/fork_windows.cc +2 -2
  1337. data/src/core/lib/iomgr/internal_errqueue.cc +2 -3
  1338. data/src/core/lib/iomgr/iocp_windows.cc +4 -6
  1339. data/src/core/lib/iomgr/iomgr.cc +7 -9
  1340. data/src/core/lib/iomgr/iomgr.h +1 -2
  1341. data/src/core/lib/iomgr/iomgr_internal.cc +1 -2
  1342. data/src/core/lib/iomgr/iomgr_internal.h +1 -2
  1343. data/src/core/lib/iomgr/iomgr_posix.cc +2 -1
  1344. data/src/core/lib/iomgr/iomgr_windows.cc +4 -3
  1345. data/src/core/lib/iomgr/lockfree_event.cc +3 -4
  1346. data/src/core/lib/iomgr/nameser.h +1 -1
  1347. data/src/core/lib/iomgr/polling_entity.cc +5 -11
  1348. data/src/core/lib/iomgr/pollset_set_windows.cc +1 -2
  1349. data/src/core/lib/iomgr/pollset_windows.cc +2 -2
  1350. data/src/core/lib/iomgr/port.h +2 -2
  1351. data/src/core/lib/iomgr/resolve_address.cc +3 -4
  1352. data/src/core/lib/iomgr/resolve_address.h +4 -6
  1353. data/src/core/lib/iomgr/resolve_address_impl.h +1 -2
  1354. data/src/core/lib/iomgr/resolve_address_posix.cc +6 -9
  1355. data/src/core/lib/iomgr/resolve_address_posix.h +2 -2
  1356. data/src/core/lib/iomgr/resolve_address_windows.cc +8 -12
  1357. data/src/core/lib/iomgr/resolve_address_windows.h +2 -2
  1358. data/src/core/lib/iomgr/resolved_address.h +1 -2
  1359. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +3 -5
  1360. data/src/core/lib/iomgr/socket_mutator.cc +1 -1
  1361. data/src/core/lib/iomgr/socket_mutator.h +1 -2
  1362. data/src/core/lib/iomgr/socket_utils.h +1 -2
  1363. data/src/core/lib/iomgr/socket_utils_common_posix.cc +6 -7
  1364. data/src/core/lib/iomgr/socket_utils_linux.cc +1 -1
  1365. data/src/core/lib/iomgr/socket_utils_posix.cc +23 -13
  1366. data/src/core/lib/iomgr/socket_utils_posix.h +12 -2
  1367. data/src/core/lib/iomgr/socket_utils_windows.cc +1 -1
  1368. data/src/core/lib/iomgr/socket_windows.cc +3 -5
  1369. data/src/core/lib/iomgr/socket_windows.h +1 -2
  1370. data/src/core/lib/iomgr/tcp_client_cfstream.cc +13 -16
  1371. data/src/core/lib/iomgr/tcp_client_posix.cc +16 -22
  1372. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  1373. data/src/core/lib/iomgr/tcp_client_windows.cc +6 -8
  1374. data/src/core/lib/iomgr/tcp_posix.cc +70 -45
  1375. data/src/core/lib/iomgr/tcp_posix.h +10 -2
  1376. data/src/core/lib/iomgr/tcp_server.h +2 -2
  1377. data/src/core/lib/iomgr/tcp_server_posix.cc +19 -15
  1378. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -3
  1379. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +4 -9
  1380. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +4 -6
  1381. data/src/core/lib/iomgr/tcp_server_windows.cc +38 -30
  1382. data/src/core/lib/iomgr/tcp_windows.cc +4 -6
  1383. data/src/core/lib/iomgr/timer.h +2 -2
  1384. data/src/core/lib/iomgr/timer_generic.cc +9 -11
  1385. data/src/core/lib/iomgr/timer_heap.cc +2 -3
  1386. data/src/core/lib/iomgr/timer_manager.cc +5 -15
  1387. data/src/core/lib/iomgr/timer_manager.h +1 -2
  1388. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -4
  1389. data/src/core/lib/iomgr/unix_sockets_posix.h +3 -4
  1390. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -2
  1391. data/src/core/lib/iomgr/vsock.cc +2 -4
  1392. data/src/core/lib/iomgr/vsock.h +3 -4
  1393. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +2 -2
  1394. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +13 -6
  1395. data/src/core/lib/promise/activity.cc +4 -4
  1396. data/src/core/lib/promise/activity.h +43 -24
  1397. data/src/core/lib/promise/all_ok.h +71 -4
  1398. data/src/core/lib/promise/arena_promise.h +2 -4
  1399. data/src/core/lib/promise/cancel_callback.h +4 -4
  1400. data/src/core/lib/promise/context.h +7 -8
  1401. data/src/core/lib/promise/detail/basic_seq.h +33 -19
  1402. data/src/core/lib/promise/detail/join_state.h +20 -73
  1403. data/src/core/lib/promise/detail/promise_factory.h +92 -33
  1404. data/src/core/lib/promise/detail/promise_like.h +34 -15
  1405. data/src/core/lib/promise/detail/seq_state.h +285 -500
  1406. data/src/core/lib/promise/detail/status.h +5 -5
  1407. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +2 -3
  1408. data/src/core/lib/promise/for_each.h +23 -15
  1409. data/src/core/lib/promise/if.h +56 -28
  1410. data/src/core/lib/promise/interceptor_list.h +12 -14
  1411. data/src/core/lib/promise/latch.h +15 -9
  1412. data/src/core/lib/promise/loop.h +73 -22
  1413. data/src/core/lib/promise/map.h +230 -21
  1414. data/src/core/lib/promise/observable.h +3 -4
  1415. data/src/core/lib/promise/party.cc +119 -84
  1416. data/src/core/lib/promise/party.h +286 -65
  1417. data/src/core/lib/promise/pipe.h +15 -17
  1418. data/src/core/lib/promise/poll.h +40 -23
  1419. data/src/core/lib/promise/prioritized_race.h +17 -23
  1420. data/src/core/lib/promise/promise.h +8 -10
  1421. data/src/core/lib/promise/race.h +6 -14
  1422. data/src/core/lib/promise/seq.h +58 -45
  1423. data/src/core/lib/promise/sleep.cc +6 -6
  1424. data/src/core/lib/promise/sleep.h +19 -6
  1425. data/src/core/lib/promise/status_flag.h +51 -17
  1426. data/src/core/lib/promise/try_join.h +124 -10
  1427. data/src/core/lib/promise/try_seq.h +84 -59
  1428. data/src/core/lib/resource_quota/api.cc +4 -6
  1429. data/src/core/lib/resource_quota/api.h +2 -3
  1430. data/src/core/lib/resource_quota/arena.cc +3 -4
  1431. data/src/core/lib/resource_quota/arena.h +91 -5
  1432. data/src/core/lib/resource_quota/connection_quota.cc +2 -2
  1433. data/src/core/lib/resource_quota/connection_quota.h +9 -6
  1434. data/src/core/lib/resource_quota/memory_quota.cc +73 -60
  1435. data/src/core/lib/resource_quota/memory_quota.h +25 -17
  1436. data/src/core/lib/resource_quota/periodic_update.cc +4 -4
  1437. data/src/core/lib/resource_quota/periodic_update.h +2 -4
  1438. data/src/core/lib/resource_quota/resource_quota.h +7 -8
  1439. data/src/core/lib/resource_quota/thread_quota.cc +2 -2
  1440. data/src/core/lib/resource_quota/thread_quota.h +5 -6
  1441. data/src/core/lib/security/authorization/audit_logging.cc +5 -6
  1442. data/src/core/lib/security/authorization/audit_logging.h +5 -6
  1443. data/src/core/lib/security/authorization/authorization_engine.h +3 -3
  1444. data/src/core/lib/security/authorization/authorization_policy_provider.h +3 -4
  1445. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +1 -1
  1446. data/src/core/lib/security/authorization/evaluate_args.cc +8 -10
  1447. data/src/core/lib/security/authorization/evaluate_args.h +7 -8
  1448. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +2 -3
  1449. data/src/core/lib/security/authorization/grpc_authorization_engine.h +2 -3
  1450. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +6 -11
  1451. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +9 -10
  1452. data/src/core/lib/security/authorization/matchers.cc +2 -4
  1453. data/src/core/lib/security/authorization/matchers.h +5 -7
  1454. data/src/core/lib/security/authorization/rbac_policy.cc +3 -3
  1455. data/src/core/lib/security/authorization/rbac_policy.h +6 -8
  1456. data/src/core/lib/security/authorization/stdout_logger.cc +4 -4
  1457. data/src/core/lib/security/authorization/stdout_logger.h +4 -4
  1458. data/src/core/lib/slice/percent_encoding.cc +2 -4
  1459. data/src/core/lib/slice/slice.cc +4 -6
  1460. data/src/core/lib/slice/slice.h +11 -7
  1461. data/src/core/lib/slice/slice_buffer.cc +7 -8
  1462. data/src/core/lib/slice/slice_buffer.h +5 -6
  1463. data/src/core/lib/slice/slice_internal.h +3 -5
  1464. data/src/core/lib/slice/slice_refcount.h +2 -3
  1465. data/src/core/lib/slice/slice_string_helpers.h +1 -2
  1466. data/src/core/lib/surface/byte_buffer.cc +1 -2
  1467. data/src/core/lib/surface/byte_buffer_reader.cc +3 -5
  1468. data/src/core/lib/surface/call.cc +42 -46
  1469. data/src/core/lib/surface/call.h +10 -11
  1470. data/src/core/lib/surface/call_log_batch.cc +3 -5
  1471. data/src/core/lib/surface/call_test_only.h +1 -2
  1472. data/src/core/lib/surface/call_utils.cc +21 -64
  1473. data/src/core/lib/surface/call_utils.h +70 -26
  1474. data/src/core/lib/surface/channel.cc +7 -16
  1475. data/src/core/lib/surface/channel.h +16 -17
  1476. data/src/core/lib/surface/channel_create.cc +2 -3
  1477. data/src/core/lib/surface/channel_create.h +2 -3
  1478. data/src/core/lib/surface/channel_init.cc +5 -7
  1479. data/src/core/lib/surface/channel_init.h +6 -8
  1480. data/src/core/lib/surface/completion_queue.cc +99 -80
  1481. data/src/core/lib/surface/completion_queue.h +4 -5
  1482. data/src/core/lib/surface/completion_queue_factory.cc +1 -2
  1483. data/src/core/lib/surface/connection_context.cc +77 -0
  1484. data/src/core/lib/surface/connection_context.h +156 -0
  1485. data/src/core/lib/surface/event_string.cc +9 -3
  1486. data/src/core/lib/surface/event_string.h +2 -2
  1487. data/src/core/lib/surface/filter_stack_call.cc +60 -51
  1488. data/src/core/lib/surface/filter_stack_call.h +18 -20
  1489. data/src/core/lib/surface/init.cc +46 -21
  1490. data/src/core/lib/surface/init.h +5 -0
  1491. data/src/core/lib/surface/init_internally.h +13 -2
  1492. data/src/core/lib/surface/lame_client.cc +11 -12
  1493. data/src/core/lib/surface/lame_client.h +4 -5
  1494. data/src/core/lib/surface/legacy_channel.cc +47 -42
  1495. data/src/core/lib/surface/legacy_channel.h +8 -9
  1496. data/src/core/lib/surface/metadata_array.cc +1 -2
  1497. data/src/core/lib/surface/validate_metadata.cc +3 -4
  1498. data/src/core/lib/surface/validate_metadata.h +2 -4
  1499. data/src/core/lib/surface/version.cc +2 -2
  1500. data/src/core/lib/transport/bdp_estimator.cc +2 -3
  1501. data/src/core/lib/transport/bdp_estimator.h +3 -5
  1502. data/src/core/lib/transport/call_final_info.cc +2 -2
  1503. data/src/core/lib/transport/call_final_info.h +3 -3
  1504. data/src/core/lib/transport/connectivity_state.cc +11 -13
  1505. data/src/core/lib/transport/connectivity_state.h +7 -10
  1506. data/src/core/lib/transport/error_utils.cc +68 -15
  1507. data/src/core/lib/transport/error_utils.h +6 -7
  1508. data/src/core/lib/transport/status_conversion.cc +16 -14
  1509. data/src/core/lib/transport/status_conversion.h +6 -5
  1510. data/src/core/lib/transport/timeout_encoding.cc +22 -22
  1511. data/src/core/lib/transport/timeout_encoding.h +4 -5
  1512. data/src/core/lib/transport/transport.cc +4 -7
  1513. data/src/core/lib/transport/transport.h +24 -21
  1514. data/src/core/lib/transport/transport_framing_endpoint_extension.h +47 -0
  1515. data/src/core/lib/transport/transport_op_string.cc +5 -6
  1516. data/src/core/load_balancing/address_filtering.cc +2 -4
  1517. data/src/core/load_balancing/address_filtering.h +4 -5
  1518. data/src/core/load_balancing/backend_metric_data.h +2 -2
  1519. data/src/core/load_balancing/backend_metric_parser.cc +22 -30
  1520. data/src/core/load_balancing/backend_metric_parser.h +1 -3
  1521. data/src/core/load_balancing/child_policy_handler.cc +5 -6
  1522. data/src/core/load_balancing/child_policy_handler.h +4 -5
  1523. data/src/core/load_balancing/delegating_helper.h +7 -8
  1524. data/src/core/load_balancing/endpoint_list.cc +18 -10
  1525. data/src/core/load_balancing/endpoint_list.h +26 -21
  1526. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +12 -11
  1527. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +5 -6
  1528. data/src/core/load_balancing/grpclb/grpclb.cc +42 -62
  1529. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +1 -2
  1530. data/src/core/load_balancing/grpclb/grpclb_client_stats.cc +2 -3
  1531. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +5 -7
  1532. data/src/core/load_balancing/grpclb/load_balancer_api.cc +4 -6
  1533. data/src/core/load_balancing/grpclb/load_balancer_api.h +4 -6
  1534. data/src/core/load_balancing/health_check_client.cc +36 -68
  1535. data/src/core/load_balancing/health_check_client.h +3 -3
  1536. data/src/core/load_balancing/health_check_client_internal.h +15 -16
  1537. data/src/core/load_balancing/lb_policy.cc +4 -6
  1538. data/src/core/load_balancing/lb_policy.h +17 -27
  1539. data/src/core/load_balancing/lb_policy_factory.h +4 -5
  1540. data/src/core/load_balancing/lb_policy_registry.cc +13 -12
  1541. data/src/core/load_balancing/lb_policy_registry.h +4 -5
  1542. data/src/core/load_balancing/oob_backend_metric.cc +14 -16
  1543. data/src/core/load_balancing/oob_backend_metric.h +3 -3
  1544. data/src/core/load_balancing/oob_backend_metric_internal.h +8 -9
  1545. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +88 -94
  1546. data/src/core/load_balancing/outlier_detection/outlier_detection.h +6 -7
  1547. data/src/core/load_balancing/pick_first/pick_first.cc +78 -997
  1548. data/src/core/load_balancing/priority/priority.cc +20 -27
  1549. data/src/core/load_balancing/ring_hash/ring_hash.cc +223 -173
  1550. data/src/core/load_balancing/ring_hash/ring_hash.h +7 -15
  1551. data/src/core/load_balancing/rls/rls.cc +159 -256
  1552. data/src/core/load_balancing/rls/rls.h +97 -1
  1553. data/src/core/load_balancing/round_robin/round_robin.cc +23 -34
  1554. data/src/core/load_balancing/subchannel_interface.h +13 -6
  1555. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +8 -8
  1556. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.h +4 -5
  1557. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +35 -48
  1558. data/src/core/load_balancing/weighted_target/weighted_target.cc +19 -29
  1559. data/src/core/load_balancing/xds/cds.cc +37 -45
  1560. data/src/core/load_balancing/xds/xds_cluster_impl.cc +58 -64
  1561. data/src/core/load_balancing/xds/xds_cluster_manager.cc +20 -30
  1562. data/src/core/load_balancing/xds/xds_override_host.cc +59 -108
  1563. data/src/core/load_balancing/xds/xds_override_host.h +3 -4
  1564. data/src/core/load_balancing/xds/xds_wrr_locality.cc +21 -24
  1565. data/src/core/plugin_registry/grpc_plugin_registry.cc +3 -7
  1566. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +3 -3
  1567. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +25 -30
  1568. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +2 -3
  1569. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +4 -6
  1570. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +2 -4
  1571. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +8 -11
  1572. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +15 -19
  1573. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +7 -6
  1574. data/src/core/resolver/dns/dns_resolver_plugin.cc +4 -5
  1575. data/src/core/resolver/dns/dns_resolver_plugin.h +1 -1
  1576. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +19 -26
  1577. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +3 -4
  1578. data/src/core/resolver/dns/event_engine/service_config_helper.cc +3 -5
  1579. data/src/core/resolver/dns/event_engine/service_config_helper.h +2 -2
  1580. data/src/core/resolver/dns/native/dns_resolver.cc +11 -12
  1581. data/src/core/resolver/dns/native/dns_resolver.h +1 -1
  1582. data/src/core/resolver/endpoint_addresses.cc +1 -3
  1583. data/src/core/resolver/endpoint_addresses.h +2 -3
  1584. data/src/core/resolver/fake/fake_resolver.cc +17 -19
  1585. data/src/core/resolver/fake/fake_resolver.h +9 -10
  1586. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +21 -25
  1587. data/src/core/resolver/polling_resolver.cc +8 -13
  1588. data/src/core/resolver/polling_resolver.h +10 -11
  1589. data/src/core/resolver/resolver.h +4 -5
  1590. data/src/core/resolver/resolver_factory.h +4 -5
  1591. data/src/core/resolver/resolver_registry.cc +6 -5
  1592. data/src/core/resolver/resolver_registry.h +4 -5
  1593. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +5 -6
  1594. data/src/core/resolver/xds/xds_config.cc +7 -8
  1595. data/src/core/resolver/xds/xds_config.h +3 -4
  1596. data/src/core/resolver/xds/xds_dependency_manager.cc +200 -191
  1597. data/src/core/resolver/xds/xds_dependency_manager.h +29 -20
  1598. data/src/core/resolver/xds/xds_resolver.cc +98 -141
  1599. data/src/core/resolver/xds/xds_resolver_attributes.h +2 -3
  1600. data/src/core/server/server.cc +376 -92
  1601. data/src/core/server/server.h +228 -82
  1602. data/src/core/server/server_call_tracer_filter.cc +15 -12
  1603. data/src/core/server/server_call_tracer_filter.h +1 -1
  1604. data/src/core/server/server_config_selector.h +6 -7
  1605. data/src/core/server/server_config_selector_filter.cc +17 -22
  1606. data/src/core/server/xds_channel_stack_modifier.cc +3 -3
  1607. data/src/core/server/xds_channel_stack_modifier.h +5 -6
  1608. data/src/core/server/xds_server_config_fetcher.cc +121 -188
  1609. data/src/core/service_config/service_config.h +3 -5
  1610. data/src/core/service_config/service_config_call_data.h +5 -6
  1611. data/src/core/service_config/service_config_channel_arg_filter.cc +16 -26
  1612. data/src/core/service_config/service_config_impl.cc +7 -9
  1613. data/src/core/service_config/service_config_impl.h +4 -6
  1614. data/src/core/service_config/service_config_parser.cc +1 -2
  1615. data/src/core/service_config/service_config_parser.h +2 -4
  1616. data/src/core/telemetry/call_tracer.cc +12 -15
  1617. data/src/core/telemetry/call_tracer.h +13 -13
  1618. data/src/core/telemetry/histogram_view.cc +3 -3
  1619. data/src/core/telemetry/histogram_view.h +1 -2
  1620. data/src/core/telemetry/metrics.cc +47 -27
  1621. data/src/core/telemetry/metrics.h +30 -21
  1622. data/src/core/telemetry/stats.cc +1 -2
  1623. data/src/core/telemetry/stats.h +2 -4
  1624. data/src/core/telemetry/stats_data.cc +187 -2
  1625. data/src/core/telemetry/stats_data.h +124 -4
  1626. data/src/core/telemetry/tcp_tracer.h +92 -87
  1627. data/src/core/transport/auth_context.cc +236 -0
  1628. data/src/core/transport/auth_context.h +140 -0
  1629. data/src/core/tsi/alts/crypt/aes_gcm.cc +5 -8
  1630. data/src/core/tsi/alts/crypt/gsec.cc +2 -3
  1631. data/src/core/tsi/alts/crypt/gsec.h +3 -4
  1632. data/src/core/tsi/alts/frame_protector/alts_counter.cc +1 -2
  1633. data/src/core/tsi/alts/frame_protector/alts_counter.h +3 -4
  1634. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +1 -2
  1635. data/src/core/tsi/alts/frame_protector/alts_crypter.h +2 -3
  1636. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +4 -5
  1637. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +1 -2
  1638. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +1 -1
  1639. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +1 -1
  1640. data/src/core/tsi/alts/frame_protector/frame_handler.cc +4 -6
  1641. data/src/core/tsi/alts/frame_protector/frame_handler.h +1 -2
  1642. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +14 -15
  1643. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +2 -3
  1644. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +1 -1
  1645. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +33 -31
  1646. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +1 -1
  1647. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -3
  1648. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -2
  1649. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +3 -3
  1650. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +3 -5
  1651. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +1 -2
  1652. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +2 -3
  1653. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +1 -2
  1654. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +3 -5
  1655. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +3 -4
  1656. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +1 -2
  1657. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +3 -5
  1658. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +1 -2
  1659. data/src/core/tsi/fake_transport_security.cc +9 -7
  1660. data/src/core/tsi/local_transport_security.cc +4 -6
  1661. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +4 -5
  1662. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +8 -10
  1663. data/src/core/tsi/ssl/session_cache/ssl_session.h +4 -5
  1664. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +4 -5
  1665. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +7 -8
  1666. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -4
  1667. data/src/core/tsi/ssl_transport_security.cc +30 -18
  1668. data/src/core/tsi/ssl_transport_security.h +6 -8
  1669. data/src/core/tsi/ssl_transport_security_utils.cc +1 -3
  1670. data/src/core/tsi/ssl_transport_security_utils.h +3 -5
  1671. data/src/core/tsi/ssl_types.h +1 -2
  1672. data/src/core/tsi/transport_security.cc +2 -3
  1673. data/src/core/tsi/transport_security.h +1 -2
  1674. data/src/core/tsi/transport_security_interface.h +3 -4
  1675. data/src/core/util/alloc.cc +2 -5
  1676. data/src/core/util/atomic_utils.h +47 -0
  1677. data/src/core/util/avl.h +324 -0
  1678. data/src/core/util/backoff.cc +57 -0
  1679. data/src/core/util/backoff.h +86 -0
  1680. data/src/core/util/bitset.h +224 -0
  1681. data/src/core/util/check_class_size.h +48 -0
  1682. data/src/core/util/chunked_vector.h +256 -0
  1683. data/src/core/util/construct_destruct.h +41 -0
  1684. data/src/core/util/cpp_impl_of.h +49 -0
  1685. data/src/core/util/crash.cc +40 -0
  1686. data/src/core/util/crash.h +36 -0
  1687. data/src/core/util/debug_location.h +106 -0
  1688. data/src/core/util/directory_reader.h +48 -0
  1689. data/src/core/util/down_cast.h +48 -0
  1690. data/src/core/util/dual_ref_counted.h +376 -0
  1691. data/src/core/util/dump_args.cc +54 -0
  1692. data/src/core/util/dump_args.h +114 -0
  1693. data/src/core/util/env.h +52 -0
  1694. data/src/core/util/event_log.cc +87 -0
  1695. data/src/core/util/event_log.h +79 -0
  1696. data/src/core/util/examine_stack.cc +43 -0
  1697. data/src/core/util/examine_stack.h +44 -0
  1698. data/src/core/util/fork.cc +241 -0
  1699. data/src/core/util/fork.h +98 -0
  1700. data/src/core/util/gcp_metadata_query.cc +9 -12
  1701. data/src/core/util/gcp_metadata_query.h +2 -3
  1702. data/src/core/util/gethostname.h +26 -0
  1703. data/src/core/util/gethostname_fallback.cc +30 -0
  1704. data/src/core/util/gethostname_host_name_max.cc +39 -0
  1705. data/src/core/util/gethostname_sysconf.cc +39 -0
  1706. data/src/core/util/glob.h +29 -0
  1707. data/src/core/util/gpr_time.cc +266 -0
  1708. data/src/core/util/grpc_if_nametoindex.h +29 -0
  1709. data/src/core/util/grpc_if_nametoindex_posix.cc +41 -0
  1710. data/src/core/util/grpc_if_nametoindex_unsupported.cc +36 -0
  1711. data/src/core/util/host_port.cc +114 -0
  1712. data/src/core/util/host_port.h +57 -0
  1713. data/src/core/util/http_client/format_request.cc +2 -5
  1714. data/src/core/util/http_client/format_request.h +1 -2
  1715. data/src/core/util/http_client/httpcli.cc +91 -40
  1716. data/src/core/util/http_client/httpcli.h +26 -19
  1717. data/src/core/util/http_client/httpcli_security_connector.cc +14 -17
  1718. data/src/core/util/http_client/httpcli_ssl_credentials.h +2 -3
  1719. data/src/core/util/http_client/parser.cc +2 -4
  1720. data/src/core/util/http_client/parser.h +1 -3
  1721. data/src/core/util/if_list.h +4530 -0
  1722. data/src/core/util/iphone/cpu.cc +1 -2
  1723. data/src/core/util/json/json.h +1 -2
  1724. data/src/core/util/json/json_channel_args.h +2 -2
  1725. data/src/core/util/json/json_object_loader.cc +7 -8
  1726. data/src/core/util/json/json_object_loader.h +20 -21
  1727. data/src/core/util/json/json_reader.cc +6 -9
  1728. data/src/core/util/json/json_reader.h +0 -1
  1729. data/src/core/util/json/json_util.cc +4 -4
  1730. data/src/core/util/json/json_util.h +1 -2
  1731. data/src/core/util/json/json_writer.cc +4 -6
  1732. data/src/core/util/latent_see.cc +100 -70
  1733. data/src/core/util/latent_see.h +45 -20
  1734. data/src/core/util/linux/cpu.cc +4 -6
  1735. data/src/core/util/linux/env.cc +61 -0
  1736. data/src/core/util/load_file.cc +87 -0
  1737. data/src/core/util/load_file.h +33 -0
  1738. data/src/core/util/log.cc +10 -13
  1739. data/src/core/util/lru_cache.h +31 -13
  1740. data/src/core/util/manual_constructor.h +145 -0
  1741. data/src/core/util/match.h +74 -0
  1742. data/src/core/util/matchers.cc +336 -0
  1743. data/src/core/util/matchers.h +162 -0
  1744. data/src/core/util/memory.h +52 -0
  1745. data/src/core/util/mpscq.cc +108 -0
  1746. data/src/core/util/mpscq.h +98 -0
  1747. data/src/core/util/msys/tmpfile.cc +3 -4
  1748. data/src/core/util/no_destruct.h +95 -0
  1749. data/src/core/util/notification.h +66 -0
  1750. data/src/core/util/orphanable.h +153 -0
  1751. data/src/core/util/overload.h +59 -0
  1752. data/src/core/util/packed_table.h +40 -0
  1753. data/src/core/util/per_cpu.cc +34 -0
  1754. data/src/core/util/per_cpu.h +102 -0
  1755. data/src/core/util/posix/cpu.cc +3 -5
  1756. data/src/core/util/posix/directory_reader.cc +82 -0
  1757. data/src/core/util/posix/env.cc +47 -0
  1758. data/src/core/util/posix/stat.cc +54 -0
  1759. data/src/core/util/posix/string.cc +2 -3
  1760. data/src/core/util/posix/sync.cc +2 -5
  1761. data/src/core/util/posix/thd.cc +243 -0
  1762. data/src/core/util/posix/time.cc +3 -5
  1763. data/src/core/util/posix/tmpfile.cc +4 -6
  1764. data/src/core/util/random_early_detection.cc +33 -0
  1765. data/src/core/util/random_early_detection.h +61 -0
  1766. data/src/core/util/ref_counted.h +403 -0
  1767. data/src/core/util/ref_counted_ptr.h +443 -0
  1768. data/src/core/util/ref_counted_string.cc +42 -0
  1769. data/src/core/util/ref_counted_string.h +159 -0
  1770. data/src/core/util/ring_buffer.h +4 -5
  1771. data/src/core/util/single_set_ptr.h +89 -0
  1772. data/src/core/util/sorted_pack.h +89 -0
  1773. data/src/core/util/spinlock.h +1 -2
  1774. data/src/core/util/stat.h +35 -0
  1775. data/src/core/util/status_helper.cc +450 -0
  1776. data/src/core/util/status_helper.h +143 -0
  1777. data/src/core/util/strerror.cc +40 -0
  1778. data/src/core/util/strerror.h +29 -0
  1779. data/src/core/util/string.cc +6 -9
  1780. data/src/core/util/string.h +1 -3
  1781. data/src/core/util/sync.cc +3 -5
  1782. data/src/core/util/sync.h +199 -0
  1783. data/src/core/util/sync_abseil.cc +4 -7
  1784. data/src/core/util/table.h +471 -0
  1785. data/src/core/util/tchar.cc +49 -0
  1786. data/src/core/util/tchar.h +33 -0
  1787. data/src/core/util/thd.h +193 -0
  1788. data/src/core/util/time.cc +174 -204
  1789. data/src/core/util/time.h +385 -0
  1790. data/src/core/util/time_averaged_stats.cc +60 -0
  1791. data/src/core/util/time_averaged_stats.h +79 -0
  1792. data/src/core/util/time_precise.cc +2 -4
  1793. data/src/core/util/time_precise.h +0 -1
  1794. data/src/core/util/time_util.cc +80 -0
  1795. data/src/core/util/time_util.h +41 -0
  1796. data/src/core/util/tmpfile.h +0 -1
  1797. data/src/core/util/type_list.h +88 -0
  1798. data/src/core/util/unique_type_name.h +123 -0
  1799. data/src/core/util/uri.cc +378 -0
  1800. data/src/core/util/uri.h +112 -0
  1801. data/src/core/util/useful.h +13 -15
  1802. data/src/core/util/uuid_v4.cc +37 -0
  1803. data/src/core/util/uuid_v4.h +35 -0
  1804. data/src/core/util/validation_errors.cc +73 -0
  1805. data/src/core/util/validation_errors.h +144 -0
  1806. data/src/core/util/wait_for_single_owner.h +62 -0
  1807. data/src/core/util/windows/cpu.cc +1 -1
  1808. data/src/core/util/windows/directory_reader.cc +79 -0
  1809. data/src/core/util/windows/env.cc +56 -0
  1810. data/src/core/util/windows/stat.cc +50 -0
  1811. data/src/core/util/windows/string.cc +2 -3
  1812. data/src/core/util/windows/string_util.cc +5 -7
  1813. data/src/core/util/windows/sync.cc +1 -3
  1814. data/src/core/util/windows/thd.cc +182 -0
  1815. data/src/core/util/windows/time.cc +1 -4
  1816. data/src/core/util/windows/tmpfile.cc +4 -5
  1817. data/src/core/util/work_serializer.cc +298 -0
  1818. data/src/core/util/work_serializer.h +81 -0
  1819. data/src/core/util/xxhash_inline.h +29 -0
  1820. data/src/core/xds/grpc/certificate_provider_store.cc +16 -22
  1821. data/src/core/xds/grpc/certificate_provider_store.h +12 -13
  1822. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +8 -9
  1823. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +7 -8
  1824. data/src/core/xds/grpc/xds_audit_logger_registry.cc +5 -6
  1825. data/src/core/xds/grpc/xds_audit_logger_registry.h +3 -4
  1826. data/src/core/xds/grpc/xds_bootstrap_grpc.cc +23 -24
  1827. data/src/core/xds/grpc/xds_bootstrap_grpc.h +6 -6
  1828. data/src/core/xds/grpc/xds_certificate_provider.cc +18 -19
  1829. data/src/core/xds/grpc/xds_certificate_provider.h +10 -11
  1830. data/src/core/xds/grpc/xds_client_grpc.cc +74 -50
  1831. data/src/core/xds/grpc/xds_client_grpc.h +17 -9
  1832. data/src/core/xds/grpc/xds_cluster.cc +9 -4
  1833. data/src/core/xds/grpc/xds_cluster.h +34 -8
  1834. data/src/core/xds/grpc/xds_cluster_parser.cc +131 -50
  1835. data/src/core/xds/grpc/xds_cluster_parser.h +6 -2
  1836. data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +9 -11
  1837. data/src/core/xds/grpc/xds_cluster_specifier_plugin.h +5 -6
  1838. data/src/core/xds/grpc/xds_common_types.cc +3 -4
  1839. data/src/core/xds/grpc/xds_common_types.h +6 -7
  1840. data/src/core/xds/grpc/xds_common_types_parser.cc +68 -34
  1841. data/src/core/xds/grpc/xds_common_types_parser.h +15 -9
  1842. data/src/core/xds/grpc/xds_endpoint.cc +3 -4
  1843. data/src/core/xds/grpc/xds_endpoint.h +7 -5
  1844. data/src/core/xds/grpc/xds_endpoint_parser.cc +92 -56
  1845. data/src/core/xds/grpc/xds_endpoint_parser.h +1 -2
  1846. data/src/core/xds/grpc/xds_health_status.cc +4 -4
  1847. data/src/core/xds/grpc/xds_health_status.h +4 -4
  1848. data/src/core/xds/grpc/xds_http_fault_filter.cc +24 -28
  1849. data/src/core/xds/grpc/xds_http_fault_filter.h +8 -8
  1850. data/src/core/xds/grpc/xds_http_filter.h +6 -7
  1851. data/src/core/xds/grpc/xds_http_filter_registry.cc +9 -10
  1852. data/src/core/xds/grpc/xds_http_filter_registry.h +6 -7
  1853. data/src/core/xds/grpc/xds_http_gcp_authn_filter.cc +12 -13
  1854. data/src/core/xds/grpc/xds_http_gcp_authn_filter.h +6 -6
  1855. data/src/core/xds/grpc/xds_http_rbac_filter.cc +71 -61
  1856. data/src/core/xds/grpc/xds_http_rbac_filter.h +8 -8
  1857. data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +15 -16
  1858. data/src/core/xds/grpc/xds_http_stateful_session_filter.h +8 -8
  1859. data/src/core/xds/grpc/xds_lb_policy_registry.cc +9 -11
  1860. data/src/core/xds/grpc/xds_lb_policy_registry.h +4 -5
  1861. data/src/core/xds/grpc/xds_listener.cc +5 -8
  1862. data/src/core/xds/grpc/xds_listener.h +11 -12
  1863. data/src/core/xds/grpc/xds_listener_parser.cc +62 -58
  1864. data/src/core/xds/grpc/xds_listener_parser.h +3 -3
  1865. data/src/core/xds/grpc/xds_metadata.cc +5 -5
  1866. data/src/core/xds/grpc/xds_metadata.h +34 -3
  1867. data/src/core/xds/grpc/xds_metadata_parser.cc +102 -48
  1868. data/src/core/xds/grpc/xds_metadata_parser.h +1 -2
  1869. data/src/core/xds/grpc/xds_route_config.cc +12 -18
  1870. data/src/core/xds/grpc/xds_route_config.h +12 -13
  1871. data/src/core/xds/grpc/xds_route_config_parser.cc +125 -129
  1872. data/src/core/xds/grpc/xds_route_config_parser.h +8 -11
  1873. data/src/core/xds/grpc/xds_routing.cc +8 -10
  1874. data/src/core/xds/grpc/xds_routing.h +7 -9
  1875. data/src/core/xds/grpc/xds_server_grpc.cc +83 -51
  1876. data/src/core/xds/grpc/xds_server_grpc.h +28 -15
  1877. data/src/core/xds/grpc/xds_server_grpc_interface.h +33 -0
  1878. data/src/core/xds/grpc/xds_transport_grpc.cc +101 -57
  1879. data/src/core/xds/grpc/xds_transport_grpc.h +33 -20
  1880. data/src/core/xds/xds_client/lrs_client.cc +1281 -0
  1881. data/src/core/xds/xds_client/lrs_client.h +394 -0
  1882. data/src/core/xds/xds_client/xds_api.cc +28 -465
  1883. data/src/core/xds/xds_client/xds_api.h +6 -161
  1884. data/src/core/xds/xds_client/xds_backend_metric_propagation.cc +63 -0
  1885. data/src/core/xds/xds_client/xds_backend_metric_propagation.h +59 -0
  1886. data/src/core/xds/xds_client/xds_bootstrap.cc +12 -3
  1887. data/src/core/xds/xds_client/xds_bootstrap.h +25 -3
  1888. data/src/core/xds/xds_client/xds_client.cc +1086 -1296
  1889. data/src/core/xds/xds_client/xds_client.h +170 -115
  1890. data/src/core/xds/xds_client/xds_locality.h +102 -0
  1891. data/src/core/xds/xds_client/xds_metrics.h +2 -2
  1892. data/src/core/xds/xds_client/xds_resource_type.h +7 -10
  1893. data/src/core/xds/xds_client/xds_resource_type_impl.h +15 -11
  1894. data/src/core/xds/xds_client/xds_transport.h +29 -14
  1895. data/src/ruby/ext/grpc/extconf.rb +2 -1
  1896. data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -3
  1897. data/src/ruby/ext/grpc/rb_call.c +5 -5
  1898. data/src/ruby/ext/grpc/rb_call_credentials.c +5 -6
  1899. data/src/ruby/ext/grpc/rb_channel.c +6 -7
  1900. data/src/ruby/ext/grpc/rb_channel_args.c +3 -3
  1901. data/src/ruby/ext/grpc/rb_channel_credentials.c +5 -6
  1902. data/src/ruby/ext/grpc/rb_channel_credentials.h +1 -2
  1903. data/src/ruby/ext/grpc/rb_completion_queue.c +3 -4
  1904. data/src/ruby/ext/grpc/rb_compression_options.c +6 -7
  1905. data/src/ruby/ext/grpc/rb_event_thread.c +4 -5
  1906. data/src/ruby/ext/grpc/rb_grpc.c +3 -4
  1907. data/src/ruby/ext/grpc/rb_grpc.h +2 -3
  1908. data/src/ruby/ext/grpc/rb_server.c +6 -6
  1909. data/src/ruby/ext/grpc/rb_server_credentials.c +3 -3
  1910. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -2
  1911. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +5 -6
  1912. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +1 -2
  1913. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +4 -4
  1914. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +1 -2
  1915. data/src/ruby/lib/grpc/version.rb +1 -1
  1916. data/src/ruby/spec/generic/client_stub_spec.rb +20 -20
  1917. data/third_party/abseil-cpp/absl/algorithm/container.h +57 -18
  1918. data/third_party/abseil-cpp/absl/base/attributes.h +84 -0
  1919. data/third_party/abseil-cpp/absl/base/config.h +32 -51
  1920. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +0 -16
  1921. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +3 -1
  1922. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +13 -3
  1923. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -12
  1924. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +4 -4
  1925. data/third_party/abseil-cpp/absl/base/macros.h +48 -0
  1926. data/third_party/abseil-cpp/absl/base/no_destructor.h +35 -40
  1927. data/third_party/abseil-cpp/absl/base/nullability.h +33 -7
  1928. data/third_party/abseil-cpp/absl/base/optimization.h +11 -0
  1929. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  1930. data/third_party/abseil-cpp/absl/base/prefetch.h +1 -1
  1931. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +68 -12
  1932. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +60 -6
  1933. data/third_party/abseil-cpp/absl/container/hash_container_defaults.h +45 -0
  1934. data/third_party/abseil-cpp/absl/container/inlined_vector.h +13 -0
  1935. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +20 -11
  1936. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +15 -16
  1937. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +34 -1
  1938. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +68 -1
  1939. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +50 -0
  1940. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +22 -7
  1941. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +26 -8
  1942. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +39 -35
  1943. data/third_party/abseil-cpp/absl/container/internal/layout.h +190 -74
  1944. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +8 -6
  1945. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +334 -71
  1946. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1299 -458
  1947. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +19 -17
  1948. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.cc +4 -3
  1949. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +2 -1
  1950. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +12 -8
  1951. data/third_party/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +1 -1
  1952. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +11 -7
  1953. data/third_party/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +18 -17
  1954. data/third_party/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence.h +126 -0
  1955. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +258 -0
  1956. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +55 -0
  1957. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1057 -86
  1958. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +3 -0
  1959. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.cc +925 -0
  1960. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.h +42 -0
  1961. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +43 -16
  1962. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +8 -7
  1963. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +10 -7
  1964. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.cc +70 -0
  1965. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.h +47 -0
  1966. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +11 -0
  1967. data/third_party/abseil-cpp/absl/flags/flag.h +2 -0
  1968. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +117 -30
  1969. data/third_party/abseil-cpp/absl/flags/internal/flag.h +192 -30
  1970. data/third_party/abseil-cpp/absl/flags/reflection.cc +10 -0
  1971. data/third_party/abseil-cpp/absl/functional/any_invocable.h +13 -3
  1972. data/third_party/abseil-cpp/absl/functional/bind_front.h +3 -2
  1973. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +7 -7
  1974. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +9 -9
  1975. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +1 -1
  1976. data/third_party/abseil-cpp/absl/hash/internal/hash.h +13 -3
  1977. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +60 -28
  1978. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +4 -0
  1979. data/third_party/abseil-cpp/absl/log/absl_vlog_is_on.h +3 -3
  1980. data/third_party/abseil-cpp/absl/log/globals.h +28 -15
  1981. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +20 -0
  1982. data/third_party/abseil-cpp/absl/log/internal/check_op.h +63 -21
  1983. data/third_party/abseil-cpp/absl/log/internal/conditions.h +2 -2
  1984. data/third_party/abseil-cpp/absl/log/internal/log_impl.h +23 -23
  1985. data/third_party/abseil-cpp/absl/log/internal/log_message.cc +104 -47
  1986. data/third_party/abseil-cpp/absl/log/internal/log_message.h +23 -4
  1987. data/third_party/abseil-cpp/absl/log/internal/nullstream.h +1 -10
  1988. data/third_party/abseil-cpp/absl/log/internal/strip.h +36 -0
  1989. data/third_party/abseil-cpp/absl/log/log.h +5 -1
  1990. data/third_party/abseil-cpp/absl/log/log_sink.h +11 -4
  1991. data/third_party/abseil-cpp/absl/log/vlog_is_on.h +3 -3
  1992. data/third_party/abseil-cpp/absl/meta/type_traits.h +138 -42
  1993. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -3
  1994. data/third_party/abseil-cpp/absl/numeric/int128.h +35 -5
  1995. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +14 -0
  1996. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +18 -0
  1997. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +6 -2
  1998. data/third_party/abseil-cpp/absl/random/beta_distribution.h +8 -8
  1999. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +9 -7
  2000. data/third_party/abseil-cpp/absl/random/distributions.h +11 -11
  2001. data/third_party/abseil-cpp/absl/random/seed_sequences.h +2 -0
  2002. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +61 -2
  2003. data/third_party/abseil-cpp/absl/status/status.cc +0 -4
  2004. data/third_party/abseil-cpp/absl/status/status.h +4 -4
  2005. data/third_party/abseil-cpp/absl/status/statusor.h +108 -142
  2006. data/third_party/abseil-cpp/absl/strings/ascii.cc +32 -71
  2007. data/third_party/abseil-cpp/absl/strings/cord.cc +20 -15
  2008. data/third_party/abseil-cpp/absl/strings/cord.h +68 -7
  2009. data/third_party/abseil-cpp/absl/strings/escaping.cc +96 -21
  2010. data/third_party/abseil-cpp/absl/strings/escaping.h +25 -8
  2011. data/third_party/abseil-cpp/absl/strings/has_absl_stringify.h +1 -0
  2012. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +10 -0
  2013. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +29 -9
  2014. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +2 -2
  2015. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.cc +19 -13
  2016. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.h +23 -13
  2017. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +24 -24
  2018. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +12 -7
  2019. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.h +9 -4
  2020. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +5 -2
  2021. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +23 -2
  2022. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +5 -1
  2023. data/third_party/abseil-cpp/absl/strings/numbers.cc +107 -333
  2024. data/third_party/abseil-cpp/absl/strings/numbers.h +12 -151
  2025. data/third_party/abseil-cpp/absl/strings/str_cat.cc +49 -142
  2026. data/third_party/abseil-cpp/absl/strings/str_cat.h +70 -85
  2027. data/third_party/abseil-cpp/absl/strings/str_format.h +1 -1
  2028. data/third_party/abseil-cpp/absl/strings/str_join.h +19 -5
  2029. data/third_party/abseil-cpp/absl/strings/str_split.h +2 -2
  2030. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  2031. data/third_party/abseil-cpp/absl/strings/substitute.cc +4 -0
  2032. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +11 -2
  2033. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +5 -0
  2034. data/third_party/abseil-cpp/absl/synchronization/mutex.h +5 -4
  2035. data/third_party/abseil-cpp/absl/time/civil_time.h +2 -2
  2036. data/third_party/abseil-cpp/absl/time/clock.cc +15 -1
  2037. data/third_party/abseil-cpp/absl/time/duration.cc +58 -53
  2038. data/third_party/abseil-cpp/absl/time/format.cc +2 -1
  2039. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +1 -1
  2040. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -29
  2041. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +3 -3
  2042. data/third_party/abseil-cpp/absl/time/time.h +73 -29
  2043. data/third_party/abseil-cpp/absl/types/compare.h +505 -0
  2044. data/third_party/abseil-cpp/absl/types/internal/optional.h +2 -2
  2045. data/third_party/abseil-cpp/absl/types/internal/variant.h +55 -67
  2046. data/third_party/abseil-cpp/absl/types/optional.h +15 -18
  2047. data/third_party/abseil-cpp/absl/types/span.h +3 -2
  2048. data/third_party/abseil-cpp/absl/types/variant.h +19 -24
  2049. data/third_party/abseil-cpp/absl/utility/utility.h +3 -41
  2050. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.cc +243 -0
  2051. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.cc +53 -0
  2052. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.cc +47 -0
  2053. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.cc +42 -0
  2054. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.cc +109 -0
  2055. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.cc +43 -0
  2056. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.cc +424 -0
  2057. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.cc +239 -0
  2058. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.cc +193 -0
  2059. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.cc +32 -0
  2060. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.cc +415 -0
  2061. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.cc +206 -0
  2062. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.cc +224 -0
  2063. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.cc +172 -0
  2064. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.cc +109 -0
  2065. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.cc +355 -0
  2066. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.cc +61 -0
  2067. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.cc +56 -0
  2068. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.cc +63 -0
  2069. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.cc +52 -0
  2070. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +13 -57
  2071. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.cc +241 -0
  2072. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.cc +932 -0
  2073. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.cc +669 -0
  2074. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.cc +164 -0
  2075. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.cc +276 -0
  2076. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.cc +84 -0
  2077. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.cc +229 -0
  2078. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.cc +434 -0
  2079. data/third_party/boringssl-with-bazel/src/crypto/bcm_support.h +19 -13
  2080. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.cc +658 -0
  2081. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.cc +268 -0
  2082. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.cc +511 -0
  2083. data/third_party/boringssl-with-bazel/src/crypto/bio/errno.cc +50 -0
  2084. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.cc +193 -0
  2085. data/third_party/boringssl-with-bazel/src/crypto/bio/file.cc +292 -0
  2086. data/third_party/boringssl-with-bazel/src/crypto/bio/hexdump.cc +152 -0
  2087. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +13 -55
  2088. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.cc +446 -0
  2089. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.cc +59 -0
  2090. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.cc +147 -0
  2091. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.cc +133 -0
  2092. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.cc +169 -0
  2093. data/third_party/boringssl-with-bazel/src/crypto/bn/bn_asn1.cc +57 -0
  2094. data/third_party/boringssl-with-bazel/src/crypto/bn/convert.cc +423 -0
  2095. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.cc +118 -0
  2096. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.cc +53 -0
  2097. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.cc +266 -0
  2098. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.cc +702 -0
  2099. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.cc +912 -0
  2100. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +13 -13
  2101. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.cc +156 -0
  2102. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.cc +224 -0
  2103. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +18 -18
  2104. data/third_party/boringssl-with-bazel/src/crypto/cipher/derive_key.cc +110 -0
  2105. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aesctrhmac.cc +279 -0
  2106. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aesgcmsiv.cc +845 -0
  2107. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_chacha20poly1305.cc +341 -0
  2108. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_des.cc +198 -0
  2109. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_null.cc +51 -0
  2110. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_rc2.cc +417 -0
  2111. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_rc4.cc +54 -0
  2112. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_tls.cc +599 -0
  2113. data/third_party/boringssl-with-bazel/src/crypto/cipher/get_cipher.cc +85 -0
  2114. data/third_party/boringssl-with-bazel/src/crypto/cipher/internal.h +240 -0
  2115. data/third_party/boringssl-with-bazel/src/crypto/cipher/tls_cbc.cc +476 -0
  2116. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.cc +631 -0
  2117. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +13 -13
  2118. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.cc +73 -0
  2119. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_fuchsia.cc +53 -0
  2120. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_linux.cc +60 -0
  2121. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_openbsd.cc +59 -0
  2122. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_sysreg.cc +92 -0
  2123. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_win.cc +39 -0
  2124. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.cc +53 -0
  2125. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.cc +150 -0
  2126. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.h +13 -13
  2127. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.cc +287 -0
  2128. data/third_party/boringssl-with-bazel/src/crypto/crypto.cc +181 -0
  2129. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.cc +2154 -0
  2130. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_64_adx.cc +18 -0
  2131. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +13 -13
  2132. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +13 -13
  2133. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.cc +529 -0
  2134. data/third_party/boringssl-with-bazel/src/crypto/des/des.cc +829 -0
  2135. data/third_party/boringssl-with-bazel/src/crypto/des/internal.h +27 -69
  2136. data/third_party/boringssl-with-bazel/src/crypto/dh/dh_asn1.cc +124 -0
  2137. data/third_party/boringssl-with-bazel/src/crypto/dh/params.cc +442 -0
  2138. data/third_party/boringssl-with-bazel/src/crypto/digest/digest_extra.cc +306 -0
  2139. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.cc +951 -0
  2140. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.cc +379 -0
  2141. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +13 -15
  2142. data/third_party/boringssl-with-bazel/src/crypto/ec/ec_asn1.cc +570 -0
  2143. data/third_party/boringssl-with-bazel/src/crypto/ec/ec_derive.cc +96 -0
  2144. data/third_party/boringssl-with-bazel/src/crypto/ec/hash_to_curve.cc +510 -0
  2145. data/third_party/boringssl-with-bazel/src/crypto/ec/internal.h +78 -0
  2146. data/third_party/boringssl-with-bazel/src/crypto/ecdh/ecdh.cc +73 -0
  2147. data/third_party/boringssl-with-bazel/src/crypto/ecdsa/ecdsa_asn1.cc +357 -0
  2148. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.cc +95 -0
  2149. data/third_party/boringssl-with-bazel/src/crypto/err/err.cc +810 -0
  2150. data/third_party/boringssl-with-bazel/src/crypto/err/internal.h +13 -13
  2151. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.cc +379 -0
  2152. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.cc +471 -0
  2153. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.cc +440 -0
  2154. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +13 -55
  2155. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh.cc +153 -0
  2156. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh_asn1.cc +142 -0
  2157. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.cc +279 -0
  2158. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.cc +230 -0
  2159. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.cc +286 -0
  2160. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.cc +103 -0
  2161. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.cc +225 -0
  2162. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.cc +236 -0
  2163. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.cc +609 -0
  2164. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.cc +198 -0
  2165. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.cc +109 -0
  2166. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.cc +237 -0
  2167. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.cc +98 -0
  2168. data/third_party/boringssl-with-bazel/src/crypto/evp/print.cc +342 -0
  2169. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.cc +216 -0
  2170. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.cc +114 -0
  2171. data/third_party/boringssl-with-bazel/src/crypto/ex_data.cc +141 -0
  2172. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.cc.inc +191 -0
  2173. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.cc.inc +1281 -0
  2174. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/cbc.cc.inc +130 -0
  2175. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/cfb.cc.inc +166 -0
  2176. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/ctr.cc.inc +100 -0
  2177. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/gcm.cc.inc +604 -0
  2178. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/gcm_nohw.cc.inc +302 -0
  2179. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +419 -70
  2180. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.cc.inc +208 -0
  2181. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.cc.inc +84 -0
  2182. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/ofb.cc.inc +53 -0
  2183. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/polyval.cc.inc +89 -0
  2184. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.cc +282 -0
  2185. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm_interface.h +665 -25
  2186. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.cc.inc +269 -0
  2187. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/x86_64-gcc.cc.inc +554 -0
  2188. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.cc.inc +374 -0
  2189. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.cc.inc +225 -0
  2190. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.cc.inc +159 -0
  2191. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.cc.inc +191 -0
  2192. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.cc.inc +825 -0
  2193. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.cc.inc +87 -0
  2194. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.cc.inc +1227 -0
  2195. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.cc.inc +300 -0
  2196. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.cc.inc +339 -0
  2197. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.cc.inc +582 -0
  2198. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +25 -134
  2199. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.cc.inc +108 -0
  2200. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.cc.inc +430 -0
  2201. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.cc.inc +222 -0
  2202. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.cc.inc +698 -0
  2203. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.cc.inc +980 -0
  2204. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.cc.inc +260 -0
  2205. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.cc.inc +142 -0
  2206. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +20 -17
  2207. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.cc.inc +320 -0
  2208. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.cc.inc +459 -0
  2209. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.cc.inc +295 -0
  2210. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.cc.inc +672 -0
  2211. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.cc.inc +1242 -0
  2212. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aesccm.cc.inc +409 -0
  2213. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +14 -65
  2214. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cmac/cmac.cc.inc +288 -0
  2215. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +26 -22
  2216. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.cc.inc +203 -0
  2217. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.cc.inc +443 -0
  2218. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/internal.h +13 -15
  2219. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.cc.inc +250 -0
  2220. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.cc.inc +178 -0
  2221. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/internal.h +13 -55
  2222. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +13 -47
  2223. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digestsign/digestsign.cc.inc +226 -0
  2224. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/builtin_curves.h +91 -91
  2225. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.cc.inc +986 -0
  2226. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.cc.inc +501 -0
  2227. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.cc.inc +439 -0
  2228. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.cc.inc +104 -0
  2229. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +19 -66
  2230. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.cc.inc +306 -0
  2231. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.cc.inc +1163 -0
  2232. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz-table.h +15 -10
  2233. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.cc.inc +741 -0
  2234. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.h +22 -17
  2235. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.cc.inc +749 -0
  2236. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +13 -13
  2237. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.cc.inc +179 -0
  2238. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.cc.inc +284 -0
  2239. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.cc.inc +269 -0
  2240. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.cc.inc +255 -0
  2241. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.cc.inc +221 -0
  2242. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.cc.inc +88 -0
  2243. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.cc.inc +278 -0
  2244. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +13 -13
  2245. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.cc +28 -0
  2246. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/hkdf.cc.inc +112 -0
  2247. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.cc.inc +215 -0
  2248. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/keccak/internal.h +70 -0
  2249. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/keccak/keccak.cc.inc +279 -0
  2250. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mldsa/mldsa.cc.inc +1993 -0
  2251. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mlkem/mlkem.cc.inc +1165 -0
  2252. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.cc.inc +214 -0
  2253. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +18 -24
  2254. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.cc.inc +483 -0
  2255. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.cc.inc +147 -0
  2256. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +13 -56
  2257. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.cc.inc +379 -0
  2258. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.cc.inc +983 -0
  2259. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.cc.inc +1296 -0
  2260. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.cc.inc +129 -0
  2261. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.cc.inc +1042 -0
  2262. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +34 -34
  2263. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.cc.inc +327 -0
  2264. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +43 -57
  2265. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.cc.inc +390 -0
  2266. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.cc.inc +299 -0
  2267. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.cc.inc +473 -0
  2268. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/address.h +119 -0
  2269. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/fors.cc.inc +169 -0
  2270. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/fors.h +58 -0
  2271. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/merkle.cc.inc +161 -0
  2272. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/merkle.h +70 -0
  2273. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/params.h +78 -0
  2274. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/slhdsa.cc.inc +329 -0
  2275. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/thash.cc.inc +173 -0
  2276. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/thash.h +85 -0
  2277. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/wots.cc.inc +171 -0
  2278. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/wots.h +50 -0
  2279. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +13 -13
  2280. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.cc.inc +180 -0
  2281. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.cc +1095 -0
  2282. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.cc +2185 -0
  2283. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +13 -13
  2284. data/third_party/boringssl-with-bazel/src/crypto/internal.h +262 -445
  2285. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +13 -13
  2286. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.cc +869 -0
  2287. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +31 -75
  2288. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.cc +309 -0
  2289. data/third_party/boringssl-with-bazel/src/crypto/md4/md4.cc +194 -0
  2290. data/third_party/boringssl-with-bazel/src/crypto/md5/internal.h +37 -0
  2291. data/third_party/boringssl-with-bazel/src/crypto/md5/md5.cc +243 -0
  2292. data/third_party/boringssl-with-bazel/src/crypto/mem.cc +583 -0
  2293. data/third_party/boringssl-with-bazel/src/crypto/mldsa/mldsa.cc +90 -0
  2294. data/third_party/boringssl-with-bazel/src/crypto/mlkem/mlkem.cc +97 -1042
  2295. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.cc +519 -0
  2296. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +14 -56
  2297. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_xref.cc +80 -0
  2298. data/third_party/boringssl-with-bazel/src/crypto/pem/internal.h +44 -0
  2299. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.cc +149 -0
  2300. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.cc +254 -0
  2301. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.cc +741 -0
  2302. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.cc +45 -0
  2303. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.cc +208 -0
  2304. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.cc +141 -0
  2305. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.cc +22 -0
  2306. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.cc +22 -0
  2307. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +13 -13
  2308. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.cc +193 -0
  2309. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.cc +526 -0
  2310. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +13 -54
  2311. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.cc +275 -0
  2312. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.cc +487 -0
  2313. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.cc +1304 -0
  2314. data/third_party/boringssl-with-bazel/src/crypto/poly1305/internal.h +13 -13
  2315. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.cc +314 -0
  2316. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.cc +310 -0
  2317. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.cc +850 -0
  2318. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +13 -13
  2319. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.cc +262 -0
  2320. data/third_party/boringssl-with-bazel/src/crypto/rand/deterministic.cc +65 -0
  2321. data/third_party/boringssl-with-bazel/src/crypto/rand/fork_detect.cc +194 -0
  2322. data/third_party/boringssl-with-bazel/src/crypto/rand/forkunsafe.cc +44 -0
  2323. data/third_party/boringssl-with-bazel/src/crypto/rand/getentropy.cc +60 -0
  2324. data/third_party/boringssl-with-bazel/src/crypto/rand/getrandom_fillin.h +64 -0
  2325. data/third_party/boringssl-with-bazel/src/crypto/rand/ios.cc +42 -0
  2326. data/third_party/boringssl-with-bazel/src/crypto/rand/passive.cc +178 -0
  2327. data/third_party/boringssl-with-bazel/src/crypto/rand/rand.cc +77 -0
  2328. data/third_party/boringssl-with-bazel/src/crypto/rand/sysrand_internal.h +37 -0
  2329. data/third_party/boringssl-with-bazel/src/crypto/rand/trusty.cc +46 -0
  2330. data/third_party/boringssl-with-bazel/src/crypto/rand/urandom.cc +328 -0
  2331. data/third_party/boringssl-with-bazel/src/crypto/rand/windows.cc +102 -0
  2332. data/third_party/boringssl-with-bazel/src/crypto/rc4/rc4.cc +56 -0
  2333. data/third_party/boringssl-with-bazel/src/crypto/refcount.cc +59 -0
  2334. data/third_party/boringssl-with-bazel/src/crypto/rsa/internal.h +36 -0
  2335. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_asn1.cc +283 -0
  2336. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_crypt.cc +531 -0
  2337. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_extra.cc +19 -0
  2338. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_print.cc +27 -0
  2339. data/third_party/boringssl-with-bazel/src/crypto/sha/sha1.cc +52 -0
  2340. data/third_party/boringssl-with-bazel/src/crypto/sha/sha256.cc +87 -0
  2341. data/third_party/boringssl-with-bazel/src/crypto/sha/sha512.cc +104 -0
  2342. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.cc +79 -0
  2343. data/third_party/boringssl-with-bazel/src/crypto/slhdsa/slhdsa.cc +113 -0
  2344. data/third_party/boringssl-with-bazel/src/crypto/spake2plus/internal.h +204 -0
  2345. data/third_party/boringssl-with-bazel/src/crypto/spake2plus/spake2plus.cc +501 -0
  2346. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.cc +496 -0
  2347. data/third_party/boringssl-with-bazel/src/crypto/thread.cc +68 -0
  2348. data/third_party/boringssl-with-bazel/src/crypto/thread_none.cc +51 -0
  2349. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.cc +151 -0
  2350. data/third_party/boringssl-with-bazel/src/crypto/thread_win.cc +240 -0
  2351. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +13 -13
  2352. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.cc +1656 -0
  2353. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.cc +685 -0
  2354. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.cc +1263 -0
  2355. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.cc +52 -0
  2356. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.cc +97 -0
  2357. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.cc +74 -0
  2358. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.cc +136 -0
  2359. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.cc +542 -0
  2360. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.cc +355 -0
  2361. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.cc +227 -0
  2362. data/third_party/boringssl-with-bazel/src/crypto/x509/ext_dat.h +13 -55
  2363. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.cc +37 -0
  2364. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +13 -57
  2365. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.cc +185 -0
  2366. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.cc +796 -0
  2367. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.cc +364 -0
  2368. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.cc +103 -0
  2369. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.cc +203 -0
  2370. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.cc +287 -0
  2371. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.cc +79 -0
  2372. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akey.cc +181 -0
  2373. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akeya.cc +31 -0
  2374. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_alt.cc +593 -0
  2375. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bcons.cc +95 -0
  2376. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bitst.cc +102 -0
  2377. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_conf.cc +374 -0
  2378. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_cpols.cc +444 -0
  2379. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_crld.cc +557 -0
  2380. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_enum.cc +73 -0
  2381. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_extku.cc +114 -0
  2382. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_genn.cc +228 -0
  2383. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ia5.cc +79 -0
  2384. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.cc +164 -0
  2385. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_int.cc +81 -0
  2386. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_lib.cc +304 -0
  2387. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ncons.cc +514 -0
  2388. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ocsp.cc +89 -0
  2389. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pcons.cc +101 -0
  2390. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pmaps.cc +109 -0
  2391. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_prn.cc +183 -0
  2392. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_purp.cc +590 -0
  2393. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_skey.cc +131 -0
  2394. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.cc +1342 -0
  2395. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.cc +47 -0
  2396. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.cc +186 -0
  2397. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.cc +238 -0
  2398. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.cc +66 -0
  2399. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.cc +44 -0
  2400. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.cc +139 -0
  2401. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.cc +554 -0
  2402. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.cc +164 -0
  2403. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.cc +257 -0
  2404. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.cc +198 -0
  2405. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.cc +118 -0
  2406. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.cc +147 -0
  2407. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.cc +249 -0
  2408. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.cc +1600 -0
  2409. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.cc +440 -0
  2410. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.cc +235 -0
  2411. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.cc +365 -0
  2412. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.cc +67 -0
  2413. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.cc +91 -0
  2414. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.cc +107 -0
  2415. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.cc +318 -0
  2416. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.cc +55 -0
  2417. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.cc +342 -0
  2418. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.cc +36 -0
  2419. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.cc +492 -0
  2420. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.cc +170 -0
  2421. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.cc +74 -0
  2422. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.cc +51 -0
  2423. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.cc +34 -0
  2424. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.cc +28 -0
  2425. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.cc +506 -0
  2426. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.cc +169 -0
  2427. data/third_party/boringssl-with-bazel/src/gen/crypto/err_data.cc +1529 -0
  2428. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +13 -13
  2429. data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +13 -47
  2430. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +16 -76
  2431. data/third_party/boringssl-with-bazel/src/include/openssl/asm_base.h +14 -14
  2432. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +23 -62
  2433. data/third_party/boringssl-with-bazel/src/include/openssl/asn1_mac.h +13 -13
  2434. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +248 -328
  2435. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +24 -55
  2436. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +13 -55
  2437. data/third_party/boringssl-with-bazel/src/include/openssl/bcm_public.h +82 -0
  2438. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +13 -55
  2439. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +13 -13
  2440. data/third_party/boringssl-with-bazel/src/include/openssl/blowfish.h +13 -55
  2441. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +14 -121
  2442. data/third_party/boringssl-with-bazel/src/include/openssl/buf.h +13 -55
  2443. data/third_party/boringssl-with-bazel/src/include/openssl/buffer.h +13 -13
  2444. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +31 -16
  2445. data/third_party/boringssl-with-bazel/src/include/openssl/cast.h +13 -55
  2446. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +13 -13
  2447. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +31 -59
  2448. data/third_party/boringssl-with-bazel/src/include/openssl/cmac.h +13 -13
  2449. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +13 -55
  2450. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +13 -13
  2451. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +25 -14
  2452. data/third_party/boringssl-with-bazel/src/include/openssl/ctrdrbg.h +13 -13
  2453. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +13 -13
  2454. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +13 -55
  2455. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +17 -55
  2456. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +19 -56
  2457. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +17 -58
  2458. data/third_party/boringssl-with-bazel/src/include/openssl/dtls1.h +13 -13
  2459. data/third_party/boringssl-with-bazel/src/include/openssl/e_os2.h +13 -13
  2460. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +14 -66
  2461. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +31 -72
  2462. data/third_party/boringssl-with-bazel/src/include/openssl/ecdh.h +14 -65
  2463. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +13 -51
  2464. data/third_party/boringssl-with-bazel/src/include/openssl/engine.h +13 -13
  2465. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +13 -107
  2466. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +14 -56
  2467. data/third_party/boringssl-with-bazel/src/include/openssl/evp_errors.h +13 -55
  2468. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +13 -107
  2469. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/kyber.h +13 -13
  2470. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +13 -13
  2471. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +13 -55
  2472. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +13 -13
  2473. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +13 -13
  2474. data/third_party/boringssl-with-bazel/src/include/openssl/is_boringssl.h +13 -13
  2475. data/third_party/boringssl-with-bazel/src/include/openssl/kdf.h +13 -13
  2476. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +13 -55
  2477. data/third_party/boringssl-with-bazel/src/include/openssl/md4.h +13 -55
  2478. data/third_party/boringssl-with-bazel/src/include/openssl/md5.h +13 -55
  2479. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +13 -55
  2480. data/third_party/boringssl-with-bazel/src/include/openssl/mldsa.h +20 -26
  2481. data/third_party/boringssl-with-bazel/src/include/openssl/mlkem.h +13 -37
  2482. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +27 -69
  2483. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +13 -55
  2484. data/third_party/boringssl-with-bazel/src/include/openssl/obj_mac.h +13 -13
  2485. data/third_party/boringssl-with-bazel/src/include/openssl/objects.h +13 -13
  2486. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +13 -13
  2487. data/third_party/boringssl-with-bazel/src/include/openssl/opensslv.h +13 -13
  2488. data/third_party/boringssl-with-bazel/src/include/openssl/ossl_typ.h +13 -13
  2489. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +22 -60
  2490. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs12.h +13 -13
  2491. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +13 -13
  2492. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +13 -55
  2493. data/third_party/boringssl-with-bazel/src/include/openssl/poly1305.h +13 -13
  2494. data/third_party/boringssl-with-bazel/src/include/openssl/pool.h +13 -13
  2495. data/third_party/boringssl-with-bazel/src/include/openssl/posix_time.h +13 -13
  2496. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +13 -13
  2497. data/third_party/boringssl-with-bazel/src/include/openssl/rc4.h +13 -55
  2498. data/third_party/boringssl-with-bazel/src/include/openssl/ripemd.h +13 -55
  2499. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +23 -63
  2500. data/third_party/boringssl-with-bazel/src/include/openssl/safestack.h +13 -13
  2501. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +13 -13
  2502. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +15 -95
  2503. data/third_party/boringssl-with-bazel/src/include/openssl/siphash.h +13 -13
  2504. data/third_party/boringssl-with-bazel/src/include/openssl/slhdsa.h +174 -0
  2505. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +24 -32
  2506. data/third_party/boringssl-with-bazel/src/include/openssl/srtp.h +13 -13
  2507. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +358 -290
  2508. data/third_party/boringssl-with-bazel/src/include/openssl/ssl3.h +15 -114
  2509. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +13 -55
  2510. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +23 -13
  2511. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +15 -57
  2512. data/third_party/boringssl-with-bazel/src/include/openssl/time.h +13 -13
  2513. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +27 -156
  2514. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +15 -15
  2515. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +13 -55
  2516. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +14 -61
  2517. data/third_party/boringssl-with-bazel/src/include/openssl/x509_vfy.h +13 -13
  2518. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +13 -13
  2519. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3_errors.h +13 -53
  2520. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +15 -14
  2521. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +680 -434
  2522. data/third_party/boringssl-with-bazel/src/ssl/d1_lib.cc +129 -174
  2523. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +176 -131
  2524. data/third_party/boringssl-with-bazel/src/ssl/d1_srtp.cc +21 -127
  2525. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +107 -104
  2526. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +311 -312
  2527. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +54 -47
  2528. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +673 -475
  2529. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +66 -73
  2530. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +61 -153
  2531. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +199 -332
  2532. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +89 -213
  2533. data/third_party/boringssl-with-bazel/src/ssl/internal.h +961 -536
  2534. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +47 -157
  2535. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +29 -159
  2536. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +18 -112
  2537. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +103 -196
  2538. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +52 -145
  2539. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +15 -20
  2540. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +117 -157
  2541. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +229 -365
  2542. data/third_party/boringssl-with-bazel/src/ssl/ssl_credential.cc +218 -32
  2543. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +13 -109
  2544. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +34 -33
  2545. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +194 -350
  2546. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +38 -83
  2547. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +101 -236
  2548. data/third_party/boringssl-with-bazel/src/ssl/ssl_stat.cc +17 -91
  2549. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +109 -157
  2550. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +44 -30
  2551. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +66 -195
  2552. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +45 -176
  2553. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +58 -42
  2554. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +147 -95
  2555. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +251 -180
  2556. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +237 -108
  2557. data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +64 -117
  2558. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +52 -134
  2559. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_32.h +6 -0
  2560. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64.h +6 -0
  2561. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64_adx.h +4 -1
  2562. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_32.h +1 -1
  2563. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +3 -0
  2564. data/third_party/upb/upb/base/internal/log2.h +3 -1
  2565. data/third_party/upb/upb/base/string_view.h +10 -0
  2566. data/third_party/upb/upb/hash/common.c +5 -1
  2567. data/third_party/upb/upb/json/decode.c +59 -13
  2568. data/third_party/upb/upb/json/decode.h +25 -3
  2569. data/third_party/upb/upb/json/encode.c +2 -2
  2570. data/third_party/upb/upb/lex/round_trip.c +10 -0
  2571. data/third_party/upb/upb/mem/alloc.h +5 -0
  2572. data/third_party/upb/upb/mem/arena.c +306 -141
  2573. data/third_party/upb/upb/mem/arena.h +56 -11
  2574. data/third_party/upb/upb/mem/arena.hpp +9 -21
  2575. data/third_party/upb/upb/mem/internal/arena.h +4 -6
  2576. data/third_party/upb/upb/message/accessors.c +2 -4
  2577. data/third_party/upb/upb/message/accessors.h +219 -379
  2578. data/third_party/upb/upb/message/compat.c +11 -14
  2579. data/third_party/upb/upb/message/compat.h +4 -3
  2580. data/third_party/upb/upb/message/copy.c +46 -37
  2581. data/third_party/upb/upb/message/internal/accessors.h +717 -36
  2582. data/third_party/upb/upb/message/internal/extension.c +29 -25
  2583. data/third_party/upb/upb/message/internal/extension.h +21 -5
  2584. data/third_party/upb/upb/message/internal/iterator.c +58 -0
  2585. data/third_party/upb/upb/message/internal/iterator.h +29 -0
  2586. data/third_party/upb/upb/message/internal/map.h +2 -3
  2587. data/third_party/upb/upb/message/internal/map_sorter.h +3 -2
  2588. data/third_party/upb/upb/message/internal/message.c +57 -39
  2589. data/third_party/upb/upb/message/internal/message.h +162 -31
  2590. data/third_party/upb/upb/message/map_sorter.c +20 -8
  2591. data/third_party/upb/upb/message/merge.c +38 -0
  2592. data/third_party/upb/upb/message/merge.h +26 -0
  2593. data/third_party/upb/upb/message/message.c +90 -38
  2594. data/third_party/upb/upb/message/message.h +64 -12
  2595. data/third_party/upb/upb/message/value.h +35 -0
  2596. data/third_party/upb/upb/mini_descriptor/build_enum.c +1 -1
  2597. data/third_party/upb/upb/mini_descriptor/decode.c +104 -138
  2598. data/third_party/upb/upb/mini_descriptor/decode.h +4 -3
  2599. data/third_party/upb/upb/mini_descriptor/internal/encode.hpp +1 -1
  2600. data/third_party/upb/upb/mini_descriptor/link.c +7 -3
  2601. data/third_party/upb/upb/mini_table/extension_registry.c +41 -11
  2602. data/third_party/upb/upb/mini_table/extension_registry.h +30 -6
  2603. data/third_party/upb/upb/mini_table/internal/extension.h +9 -0
  2604. data/third_party/upb/upb/mini_table/internal/message.c +21 -1
  2605. data/third_party/upb/upb/mini_table/internal/message.h +40 -20
  2606. data/third_party/upb/upb/mini_table/internal/sub.h +5 -0
  2607. data/third_party/upb/upb/mini_table/message.c +21 -13
  2608. data/third_party/upb/upb/mini_table/message.h +11 -1
  2609. data/third_party/upb/upb/port/atomic.h +134 -7
  2610. data/third_party/upb/upb/port/def.inc +229 -37
  2611. data/third_party/upb/upb/port/undef.inc +17 -0
  2612. data/third_party/upb/upb/reflection/common.h +1 -11
  2613. data/third_party/upb/upb/reflection/def.hpp +13 -1
  2614. data/third_party/upb/upb/reflection/def_pool.c +10 -3
  2615. data/third_party/upb/upb/reflection/descriptor_bootstrap.h +19 -0
  2616. data/third_party/upb/upb/reflection/field_def.c +11 -22
  2617. data/third_party/upb/upb/reflection/field_def.h +1 -0
  2618. data/third_party/upb/upb/reflection/file_def.c +12 -5
  2619. data/third_party/upb/upb/reflection/internal/def_builder.c +1 -1
  2620. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  2621. data/third_party/upb/upb/reflection/message.c +27 -19
  2622. data/third_party/upb/upb/reflection/message.h +5 -3
  2623. data/third_party/upb/upb/text/encode.c +51 -406
  2624. data/third_party/upb/upb/text/encode.h +1 -11
  2625. data/third_party/upb/upb/text/internal/encode.c +199 -0
  2626. data/third_party/upb/upb/text/internal/encode.h +244 -0
  2627. data/third_party/upb/upb/text/options.h +22 -0
  2628. data/third_party/upb/upb/wire/decode.c +130 -83
  2629. data/third_party/upb/upb/wire/decode.h +8 -3
  2630. data/third_party/upb/upb/wire/encode.c +113 -55
  2631. data/third_party/upb/upb/wire/encode.h +5 -0
  2632. data/third_party/upb/upb/wire/eps_copy_input_stream.h +18 -20
  2633. data/third_party/upb/upb/wire/internal/decode_fast.c +3 -0
  2634. data/third_party/upb/upb/wire/internal/decoder.h +4 -11
  2635. data/third_party/utf8_range/utf8_range.c +15 -275
  2636. data/third_party/utf8_range/utf8_range_neon.inc +117 -0
  2637. data/third_party/utf8_range/utf8_range_sse.inc +272 -0
  2638. data/third_party/zlib/deflate.c +40 -15
  2639. data/third_party/zlib/deflate.h +33 -2
  2640. data/third_party/zlib/gzguts.h +2 -6
  2641. data/third_party/zlib/inflate.c +1 -1
  2642. data/third_party/zlib/inftrees.c +3 -3
  2643. data/third_party/zlib/inftrees.h +2 -2
  2644. data/third_party/zlib/trees.c +18 -4
  2645. data/third_party/zlib/zconf.h +1 -9
  2646. data/third_party/zlib/zlib.h +12 -12
  2647. data/third_party/zlib/zutil.h +4 -25
  2648. metadata +648 -599
  2649. data/include/grpc/grpc_cronet.h +0 -37
  2650. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb.h +0 -419
  2651. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.c +0 -84
  2652. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.h +0 -30
  2653. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb.h +0 -400
  2654. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.c +0 -118
  2655. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.h +0 -33
  2656. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +0 -107
  2657. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.h +0 -32
  2658. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.c +0 -66
  2659. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.h +0 -47
  2660. data/src/core/lib/avl/avl.h +0 -325
  2661. data/src/core/lib/backoff/backoff.cc +0 -44
  2662. data/src/core/lib/backoff/backoff.h +0 -87
  2663. data/src/core/lib/backoff/random_early_detection.cc +0 -33
  2664. data/src/core/lib/backoff/random_early_detection.h +0 -62
  2665. data/src/core/lib/channel/call_finalization.h +0 -88
  2666. data/src/core/lib/channel/status_util.cc +0 -155
  2667. data/src/core/lib/channel/status_util.h +0 -80
  2668. data/src/core/lib/config/config_vars.cc +0 -152
  2669. data/src/core/lib/config/config_vars.h +0 -129
  2670. data/src/core/lib/config/config_vars_non_generated.cc +0 -49
  2671. data/src/core/lib/config/core_configuration.cc +0 -111
  2672. data/src/core/lib/config/core_configuration.h +0 -243
  2673. data/src/core/lib/config/load_config.cc +0 -79
  2674. data/src/core/lib/config/load_config.h +0 -55
  2675. data/src/core/lib/debug/event_log.cc +0 -87
  2676. data/src/core/lib/debug/event_log.h +0 -81
  2677. data/src/core/lib/gprpp/atomic_utils.h +0 -47
  2678. data/src/core/lib/gprpp/bitset.h +0 -225
  2679. data/src/core/lib/gprpp/chunked_vector.h +0 -257
  2680. data/src/core/lib/gprpp/construct_destruct.h +0 -40
  2681. data/src/core/lib/gprpp/cpp_impl_of.h +0 -49
  2682. data/src/core/lib/gprpp/crash.cc +0 -41
  2683. data/src/core/lib/gprpp/crash.h +0 -37
  2684. data/src/core/lib/gprpp/debug_location.h +0 -106
  2685. data/src/core/lib/gprpp/directory_reader.h +0 -48
  2686. data/src/core/lib/gprpp/down_cast.h +0 -48
  2687. data/src/core/lib/gprpp/dual_ref_counted.h +0 -377
  2688. data/src/core/lib/gprpp/dump_args.cc +0 -54
  2689. data/src/core/lib/gprpp/dump_args.h +0 -117
  2690. data/src/core/lib/gprpp/env.h +0 -53
  2691. data/src/core/lib/gprpp/examine_stack.cc +0 -43
  2692. data/src/core/lib/gprpp/examine_stack.h +0 -45
  2693. data/src/core/lib/gprpp/fork.cc +0 -241
  2694. data/src/core/lib/gprpp/fork.h +0 -98
  2695. data/src/core/lib/gprpp/glob.h +0 -29
  2696. data/src/core/lib/gprpp/host_port.cc +0 -115
  2697. data/src/core/lib/gprpp/host_port.h +0 -57
  2698. data/src/core/lib/gprpp/if_list.h +0 -4530
  2699. data/src/core/lib/gprpp/linux/env.cc +0 -62
  2700. data/src/core/lib/gprpp/load_file.cc +0 -76
  2701. data/src/core/lib/gprpp/load_file.h +0 -34
  2702. data/src/core/lib/gprpp/manual_constructor.h +0 -146
  2703. data/src/core/lib/gprpp/match.h +0 -75
  2704. data/src/core/lib/gprpp/memory.h +0 -52
  2705. data/src/core/lib/gprpp/mpscq.cc +0 -108
  2706. data/src/core/lib/gprpp/mpscq.h +0 -99
  2707. data/src/core/lib/gprpp/no_destruct.h +0 -95
  2708. data/src/core/lib/gprpp/notification.h +0 -67
  2709. data/src/core/lib/gprpp/orphanable.h +0 -153
  2710. data/src/core/lib/gprpp/overload.h +0 -59
  2711. data/src/core/lib/gprpp/packed_table.h +0 -40
  2712. data/src/core/lib/gprpp/per_cpu.cc +0 -34
  2713. data/src/core/lib/gprpp/per_cpu.h +0 -103
  2714. data/src/core/lib/gprpp/posix/directory_reader.cc +0 -82
  2715. data/src/core/lib/gprpp/posix/env.cc +0 -47
  2716. data/src/core/lib/gprpp/posix/stat.cc +0 -55
  2717. data/src/core/lib/gprpp/posix/thd.cc +0 -246
  2718. data/src/core/lib/gprpp/ref_counted.h +0 -403
  2719. data/src/core/lib/gprpp/ref_counted_ptr.h +0 -445
  2720. data/src/core/lib/gprpp/ref_counted_string.cc +0 -43
  2721. data/src/core/lib/gprpp/ref_counted_string.h +0 -161
  2722. data/src/core/lib/gprpp/single_set_ptr.h +0 -89
  2723. data/src/core/lib/gprpp/sorted_pack.h +0 -89
  2724. data/src/core/lib/gprpp/stat.h +0 -36
  2725. data/src/core/lib/gprpp/status_helper.cc +0 -433
  2726. data/src/core/lib/gprpp/status_helper.h +0 -162
  2727. data/src/core/lib/gprpp/strerror.cc +0 -41
  2728. data/src/core/lib/gprpp/strerror.h +0 -29
  2729. data/src/core/lib/gprpp/sync.h +0 -199
  2730. data/src/core/lib/gprpp/table.h +0 -488
  2731. data/src/core/lib/gprpp/tchar.cc +0 -49
  2732. data/src/core/lib/gprpp/tchar.h +0 -33
  2733. data/src/core/lib/gprpp/thd.h +0 -194
  2734. data/src/core/lib/gprpp/time.cc +0 -241
  2735. data/src/core/lib/gprpp/time.h +0 -379
  2736. data/src/core/lib/gprpp/time_averaged_stats.cc +0 -60
  2737. data/src/core/lib/gprpp/time_averaged_stats.h +0 -79
  2738. data/src/core/lib/gprpp/time_util.cc +0 -81
  2739. data/src/core/lib/gprpp/time_util.h +0 -41
  2740. data/src/core/lib/gprpp/type_list.h +0 -32
  2741. data/src/core/lib/gprpp/unique_type_name.h +0 -124
  2742. data/src/core/lib/gprpp/uuid_v4.cc +0 -37
  2743. data/src/core/lib/gprpp/uuid_v4.h +0 -36
  2744. data/src/core/lib/gprpp/validation_errors.cc +0 -74
  2745. data/src/core/lib/gprpp/validation_errors.h +0 -145
  2746. data/src/core/lib/gprpp/windows/directory_reader.cc +0 -79
  2747. data/src/core/lib/gprpp/windows/env.cc +0 -56
  2748. data/src/core/lib/gprpp/windows/stat.cc +0 -51
  2749. data/src/core/lib/gprpp/windows/thd.cc +0 -184
  2750. data/src/core/lib/gprpp/work_serializer.cc +0 -543
  2751. data/src/core/lib/gprpp/work_serializer.h +0 -106
  2752. data/src/core/lib/gprpp/xxhash_inline.h +0 -29
  2753. data/src/core/lib/iomgr/gethostname.h +0 -26
  2754. data/src/core/lib/iomgr/gethostname_fallback.cc +0 -30
  2755. data/src/core/lib/iomgr/gethostname_host_name_max.cc +0 -40
  2756. data/src/core/lib/iomgr/gethostname_sysconf.cc +0 -40
  2757. data/src/core/lib/iomgr/grpc_if_nametoindex.h +0 -30
  2758. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +0 -42
  2759. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +0 -37
  2760. data/src/core/lib/matchers/matchers.cc +0 -330
  2761. data/src/core/lib/matchers/matchers.h +0 -163
  2762. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +0 -70
  2763. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +0 -50
  2764. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +0 -76
  2765. data/src/core/lib/security/context/security_context.cc +0 -333
  2766. data/src/core/lib/security/context/security_context.h +0 -204
  2767. data/src/core/lib/security/credentials/alts/alts_credentials.cc +0 -116
  2768. data/src/core/lib/security/credentials/alts/alts_credentials.h +0 -123
  2769. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +0 -72
  2770. data/src/core/lib/security/credentials/alts/check_gcp_environment.h +0 -57
  2771. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +0 -68
  2772. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +0 -33
  2773. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +0 -102
  2774. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +0 -124
  2775. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +0 -45
  2776. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.h +0 -74
  2777. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +0 -55
  2778. data/src/core/lib/security/credentials/call_creds_util.cc +0 -96
  2779. data/src/core/lib/security/credentials/call_creds_util.h +0 -43
  2780. data/src/core/lib/security/credentials/channel_creds_registry.h +0 -127
  2781. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +0 -242
  2782. data/src/core/lib/security/credentials/composite/composite_credentials.cc +0 -169
  2783. data/src/core/lib/security/credentials/composite/composite_credentials.h +0 -135
  2784. data/src/core/lib/security/credentials/credentials.cc +0 -163
  2785. data/src/core/lib/security/credentials/credentials.h +0 -299
  2786. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +0 -531
  2787. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +0 -116
  2788. data/src/core/lib/security/credentials/external/aws_request_signer.cc +0 -231
  2789. data/src/core/lib/security/credentials/external/aws_request_signer.h +0 -72
  2790. data/src/core/lib/security/credentials/external/external_account_credentials.cc +0 -644
  2791. data/src/core/lib/security/credentials/external/external_account_credentials.h +0 -209
  2792. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +0 -176
  2793. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +0 -79
  2794. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +0 -223
  2795. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +0 -72
  2796. data/src/core/lib/security/credentials/fake/fake_credentials.cc +0 -105
  2797. data/src/core/lib/security/credentials/fake/fake_credentials.h +0 -125
  2798. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +0 -196
  2799. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.h +0 -90
  2800. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +0 -39
  2801. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +0 -433
  2802. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +0 -99
  2803. data/src/core/lib/security/credentials/iam/iam_credentials.cc +0 -80
  2804. data/src/core/lib/security/credentials/iam/iam_credentials.h +0 -67
  2805. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +0 -71
  2806. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +0 -61
  2807. data/src/core/lib/security/credentials/jwt/json_token.cc +0 -321
  2808. data/src/core/lib/security/credentials/jwt/json_token.h +0 -79
  2809. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +0 -184
  2810. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +0 -108
  2811. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +0 -991
  2812. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +0 -123
  2813. data/src/core/lib/security/credentials/local/local_credentials.cc +0 -68
  2814. data/src/core/lib/security/credentials/local/local_credentials.h +0 -77
  2815. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +0 -655
  2816. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +0 -198
  2817. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +0 -203
  2818. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +0 -125
  2819. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +0 -476
  2820. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +0 -146
  2821. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +0 -338
  2822. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +0 -216
  2823. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +0 -86
  2824. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +0 -412
  2825. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +0 -204
  2826. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +0 -239
  2827. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +0 -170
  2828. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +0 -162
  2829. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +0 -145
  2830. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +0 -260
  2831. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.h +0 -132
  2832. data/src/core/lib/security/credentials/tls/tls_credentials.cc +0 -171
  2833. data/src/core/lib/security/credentials/tls/tls_credentials.h +0 -73
  2834. data/src/core/lib/security/credentials/tls/tls_utils.cc +0 -128
  2835. data/src/core/lib/security/credentials/tls/tls_utils.h +0 -50
  2836. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.cc +0 -298
  2837. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.h +0 -176
  2838. data/src/core/lib/security/credentials/xds/xds_credentials.cc +0 -231
  2839. data/src/core/lib/security/credentials/xds/xds_credentials.h +0 -112
  2840. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +0 -305
  2841. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +0 -78
  2842. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +0 -316
  2843. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +0 -42
  2844. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +0 -120
  2845. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +0 -103
  2846. data/src/core/lib/security/security_connector/load_system_roots.h +0 -35
  2847. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +0 -36
  2848. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +0 -167
  2849. data/src/core/lib/security/security_connector/load_system_roots_supported.h +0 -44
  2850. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +0 -86
  2851. data/src/core/lib/security/security_connector/local/local_security_connector.cc +0 -302
  2852. data/src/core/lib/security/security_connector/local/local_security_connector.h +0 -62
  2853. data/src/core/lib/security/security_connector/security_connector.cc +0 -125
  2854. data/src/core/lib/security/security_connector/security_connector.h +0 -198
  2855. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +0 -405
  2856. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +0 -82
  2857. data/src/core/lib/security/security_connector/ssl_utils.cc +0 -630
  2858. data/src/core/lib/security/security_connector/ssl_utils.h +0 -190
  2859. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +0 -818
  2860. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +0 -286
  2861. data/src/core/lib/security/transport/auth_filters.h +0 -145
  2862. data/src/core/lib/security/transport/client_auth_filter.cc +0 -221
  2863. data/src/core/lib/security/transport/server_auth_filter.cc +0 -216
  2864. data/src/core/lib/security/util/json_util.cc +0 -70
  2865. data/src/core/lib/security/util/json_util.h +0 -43
  2866. data/src/core/lib/surface/client_call.cc +0 -429
  2867. data/src/core/lib/surface/client_call.h +0 -179
  2868. data/src/core/lib/surface/server_call.cc +0 -223
  2869. data/src/core/lib/surface/server_call.h +0 -168
  2870. data/src/core/lib/transport/call_arena_allocator.cc +0 -27
  2871. data/src/core/lib/transport/call_arena_allocator.h +0 -92
  2872. data/src/core/lib/transport/call_destination.h +0 -76
  2873. data/src/core/lib/transport/call_filters.cc +0 -254
  2874. data/src/core/lib/transport/call_filters.h +0 -1532
  2875. data/src/core/lib/transport/call_spine.cc +0 -132
  2876. data/src/core/lib/transport/call_spine.h +0 -418
  2877. data/src/core/lib/transport/call_state.cc +0 -39
  2878. data/src/core/lib/transport/call_state.h +0 -957
  2879. data/src/core/lib/transport/custom_metadata.h +0 -30
  2880. data/src/core/lib/transport/http2_errors.h +0 -41
  2881. data/src/core/lib/transport/interception_chain.cc +0 -147
  2882. data/src/core/lib/transport/interception_chain.h +0 -244
  2883. data/src/core/lib/transport/message.cc +0 -44
  2884. data/src/core/lib/transport/message.h +0 -61
  2885. data/src/core/lib/transport/metadata.cc +0 -61
  2886. data/src/core/lib/transport/metadata.h +0 -113
  2887. data/src/core/lib/transport/metadata_batch.cc +0 -376
  2888. data/src/core/lib/transport/metadata_batch.h +0 -1601
  2889. data/src/core/lib/transport/metadata_compression_traits.h +0 -67
  2890. data/src/core/lib/transport/metadata_info.cc +0 -55
  2891. data/src/core/lib/transport/metadata_info.h +0 -85
  2892. data/src/core/lib/transport/parsed_metadata.cc +0 -35
  2893. data/src/core/lib/transport/parsed_metadata.h +0 -431
  2894. data/src/core/lib/transport/simple_slice_based_metadata.h +0 -54
  2895. data/src/core/lib/uri/uri_parser.cc +0 -371
  2896. data/src/core/lib/uri/uri_parser.h +0 -101
  2897. data/src/core/resolver/binder/binder_resolver.cc +0 -153
  2898. data/src/core/util/atm.cc +0 -35
  2899. data/src/core/xds/xds_client/xds_client_stats.cc +0 -164
  2900. data/src/core/xds/xds_client/xds_client_stats.h +0 -258
  2901. data/third_party/abseil-cpp/absl/strings/internal/has_absl_stringify.h +0 -44
  2902. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +0 -284
  2903. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +0 -95
  2904. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +0 -89
  2905. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.c +0 -84
  2906. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +0 -151
  2907. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.c +0 -85
  2908. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +0 -465
  2909. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +0 -279
  2910. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +0 -235
  2911. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +0 -74
  2912. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +0 -457
  2913. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +0 -245
  2914. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +0 -259
  2915. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +0 -214
  2916. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +0 -183
  2917. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +0 -397
  2918. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +0 -103
  2919. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +0 -98
  2920. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +0 -105
  2921. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +0 -94
  2922. data/third_party/boringssl-with-bazel/src/crypto/asn1/posix_time.c +0 -241
  2923. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +0 -973
  2924. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +0 -708
  2925. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +0 -212
  2926. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +0 -317
  2927. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +0 -126
  2928. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +0 -268
  2929. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +0 -479
  2930. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +0 -726
  2931. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +0 -309
  2932. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +0 -544
  2933. data/third_party/boringssl-with-bazel/src/crypto/bio/errno.c +0 -92
  2934. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +0 -235
  2935. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +0 -334
  2936. data/third_party/boringssl-with-bazel/src/crypto/bio/hexdump.c +0 -192
  2937. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +0 -480
  2938. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.c +0 -102
  2939. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +0 -189
  2940. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +0 -133
  2941. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +0 -169
  2942. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/bn_asn1.c +0 -57
  2943. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +0 -465
  2944. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +0 -158
  2945. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.c +0 -53
  2946. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +0 -266
  2947. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +0 -718
  2948. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +0 -911
  2949. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +0 -156
  2950. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +0 -224
  2951. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/cipher_extra.c +0 -127
  2952. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/derive_key.c +0 -152
  2953. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesctrhmac.c +0 -284
  2954. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +0 -841
  2955. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +0 -348
  2956. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_des.c +0 -228
  2957. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +0 -90
  2958. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +0 -455
  2959. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +0 -94
  2960. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +0 -598
  2961. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +0 -280
  2962. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +0 -514
  2963. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +0 -672
  2964. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_apple.c +0 -75
  2965. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_fuchsia.c +0 -55
  2966. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_linux.c +0 -62
  2967. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_openbsd.c +0 -61
  2968. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_sysreg.c +0 -93
  2969. data/third_party/boringssl-with-bazel/src/crypto/cpu_aarch64_win.c +0 -41
  2970. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_freebsd.c +0 -54
  2971. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.c +0 -151
  2972. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +0 -326
  2973. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +0 -188
  2974. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +0 -2157
  2975. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_64_adx.c +0 -18
  2976. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +0 -523
  2977. data/third_party/boringssl-with-bazel/src/crypto/des/des.c +0 -871
  2978. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +0 -165
  2979. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +0 -480
  2980. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +0 -266
  2981. data/third_party/boringssl-with-bazel/src/crypto/dilithium/dilithium.c +0 -1539
  2982. data/third_party/boringssl-with-bazel/src/crypto/dilithium/internal.h +0 -58
  2983. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +0 -997
  2984. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +0 -419
  2985. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +0 -572
  2986. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +0 -96
  2987. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +0 -508
  2988. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +0 -78
  2989. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +0 -124
  2990. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +0 -411
  2991. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.c +0 -91
  2992. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +0 -903
  2993. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +0 -430
  2994. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +0 -547
  2995. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +0 -483
  2996. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh.c +0 -137
  2997. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dh_asn1.c +0 -120
  2998. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +0 -338
  2999. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +0 -274
  3000. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +0 -332
  3001. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +0 -100
  3002. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.c +0 -224
  3003. data/third_party/boringssl-with-bazel/src/crypto/evp/p_hkdf.c +0 -232
  3004. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +0 -646
  3005. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +0 -241
  3006. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +0 -106
  3007. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.c +0 -236
  3008. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +0 -146
  3009. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +0 -381
  3010. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +0 -209
  3011. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.c +0 -156
  3012. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +0 -236
  3013. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c.inc +0 -127
  3014. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.c.inc +0 -1281
  3015. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.c.inc +0 -242
  3016. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c.inc +0 -124
  3017. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +0 -279
  3018. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.c.inc +0 -310
  3019. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/x86_64-gcc.c.inc +0 -541
  3020. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c.inc +0 -428
  3021. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c.inc +0 -267
  3022. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.c.inc +0 -201
  3023. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c.inc +0 -234
  3024. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c.inc +0 -876
  3025. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c.inc +0 -87
  3026. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c.inc +0 -1320
  3027. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c.inc +0 -397
  3028. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c.inc +0 -331
  3029. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c.inc +0 -624
  3030. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.c.inc +0 -146
  3031. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c.inc +0 -532
  3032. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c.inc +0 -222
  3033. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c.inc +0 -744
  3034. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c.inc +0 -1077
  3035. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c.inc +0 -354
  3036. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c.inc +0 -137
  3037. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.c.inc +0 -363
  3038. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c.inc +0 -499
  3039. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.c.inc +0 -287
  3040. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c.inc +0 -717
  3041. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c.inc +0 -1464
  3042. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aesccm.c.inc +0 -446
  3043. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cmac/cmac.c.inc +0 -322
  3044. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c.inc +0 -245
  3045. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c.inc +0 -489
  3046. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c.inc +0 -288
  3047. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.c.inc +0 -304
  3048. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digestsign/digestsign.c.inc +0 -267
  3049. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c.inc +0 -1043
  3050. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c.inc +0 -561
  3051. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c.inc +0 -491
  3052. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c.inc +0 -104
  3053. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c.inc +0 -359
  3054. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c.inc +0 -1163
  3055. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.c.inc +0 -734
  3056. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c.inc +0 -749
  3057. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c.inc +0 -173
  3058. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c.inc +0 -336
  3059. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c.inc +0 -269
  3060. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.c.inc +0 -255
  3061. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c.inc +0 -264
  3062. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c.inc +0 -130
  3063. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c.inc +0 -317
  3064. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +0 -29
  3065. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/hkdf.c.inc +0 -112
  3066. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.c.inc +0 -256
  3067. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c.inc +0 -240
  3068. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/internal.h +0 -37
  3069. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/md5.c.inc +0 -284
  3070. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c.inc +0 -164
  3071. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c.inc +0 -200
  3072. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c.inc +0 -196
  3073. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c.inc +0 -743
  3074. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c.inc +0 -302
  3075. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +0 -428
  3076. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c.inc +0 -87
  3077. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c.inc +0 -90
  3078. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.c.inc +0 -220
  3079. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c.inc +0 -479
  3080. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c.inc +0 -241
  3081. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c.inc +0 -420
  3082. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c.inc +0 -1038
  3083. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c.inc +0 -1351
  3084. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c.inc +0 -121
  3085. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c.inc +0 -1038
  3086. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/service_indicator.c.inc +0 -328
  3087. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c.inc +0 -439
  3088. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c.inc +0 -359
  3089. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c.inc +0 -543
  3090. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c.inc +0 -218
  3091. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +0 -1092
  3092. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +0 -2234
  3093. data/third_party/boringssl-with-bazel/src/crypto/keccak/internal.h +0 -70
  3094. data/third_party/boringssl-with-bazel/src/crypto/keccak/keccak.c +0 -279
  3095. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +0 -845
  3096. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +0 -350
  3097. data/third_party/boringssl-with-bazel/src/crypto/mem.c +0 -613
  3098. data/third_party/boringssl-with-bazel/src/crypto/mldsa/internal.h +0 -73
  3099. data/third_party/boringssl-with-bazel/src/crypto/mldsa/mldsa.c +0 -1687
  3100. data/third_party/boringssl-with-bazel/src/crypto/mlkem/internal.h +0 -90
  3101. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +0 -564
  3102. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_xref.c +0 -122
  3103. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +0 -243
  3104. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +0 -294
  3105. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +0 -789
  3106. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.c +0 -87
  3107. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +0 -250
  3108. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +0 -183
  3109. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.c +0 -64
  3110. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.c +0 -64
  3111. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +0 -193
  3112. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +0 -523
  3113. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +0 -316
  3114. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +0 -527
  3115. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +0 -1352
  3116. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +0 -314
  3117. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +0 -308
  3118. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +0 -847
  3119. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +0 -261
  3120. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +0 -65
  3121. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/fork_detect.c +0 -195
  3122. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +0 -44
  3123. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +0 -60
  3124. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getrandom_fillin.h +0 -64
  3125. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/ios.c +0 -42
  3126. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +0 -174
  3127. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +0 -77
  3128. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/sysrand_internal.h +0 -37
  3129. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/trusty.c +0 -46
  3130. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/urandom.c +0 -328
  3131. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +0 -102
  3132. data/third_party/boringssl-with-bazel/src/crypto/rc4/rc4.c +0 -98
  3133. data/third_party/boringssl-with-bazel/src/crypto/refcount.c +0 -59
  3134. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/internal.h +0 -79
  3135. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_asn1.c +0 -324
  3136. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_crypt.c +0 -570
  3137. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_print.c +0 -22
  3138. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +0 -79
  3139. data/third_party/boringssl-with-bazel/src/crypto/spx/address.c +0 -101
  3140. data/third_party/boringssl-with-bazel/src/crypto/spx/address.h +0 -50
  3141. data/third_party/boringssl-with-bazel/src/crypto/spx/fors.c +0 -133
  3142. data/third_party/boringssl-with-bazel/src/crypto/spx/fors.h +0 -54
  3143. data/third_party/boringssl-with-bazel/src/crypto/spx/merkle.c +0 -150
  3144. data/third_party/boringssl-with-bazel/src/crypto/spx/merkle.h +0 -61
  3145. data/third_party/boringssl-with-bazel/src/crypto/spx/params.h +0 -71
  3146. data/third_party/boringssl-with-bazel/src/crypto/spx/spx.c +0 -140
  3147. data/third_party/boringssl-with-bazel/src/crypto/spx/spx_util.c +0 -53
  3148. data/third_party/boringssl-with-bazel/src/crypto/spx/spx_util.h +0 -44
  3149. data/third_party/boringssl-with-bazel/src/crypto/spx/thash.c +0 -136
  3150. data/third_party/boringssl-with-bazel/src/crypto/spx/thash.h +0 -70
  3151. data/third_party/boringssl-with-bazel/src/crypto/spx/wots.c +0 -135
  3152. data/third_party/boringssl-with-bazel/src/crypto/spx/wots.h +0 -45
  3153. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +0 -534
  3154. data/third_party/boringssl-with-bazel/src/crypto/thread.c +0 -110
  3155. data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -51
  3156. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +0 -150
  3157. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +0 -236
  3158. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +0 -1668
  3159. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +0 -687
  3160. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +0 -1267
  3161. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.c +0 -94
  3162. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +0 -136
  3163. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +0 -116
  3164. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +0 -178
  3165. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +0 -585
  3166. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +0 -400
  3167. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +0 -269
  3168. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.c +0 -79
  3169. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +0 -227
  3170. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +0 -786
  3171. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +0 -401
  3172. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +0 -145
  3173. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +0 -245
  3174. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +0 -329
  3175. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +0 -121
  3176. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akey.c +0 -221
  3177. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_akeya.c +0 -73
  3178. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_alt.c +0 -634
  3179. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bcons.c +0 -135
  3180. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_bitst.c +0 -141
  3181. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_conf.c +0 -416
  3182. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_cpols.c +0 -482
  3183. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_crld.c +0 -598
  3184. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_enum.c +0 -112
  3185. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_extku.c +0 -154
  3186. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_genn.c +0 -270
  3187. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ia5.c +0 -122
  3188. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.c +0 -211
  3189. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_int.c +0 -121
  3190. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_lib.c +0 -344
  3191. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ncons.c +0 -555
  3192. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_ocsp.c +0 -81
  3193. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pcons.c +0 -142
  3194. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_pmaps.c +0 -150
  3195. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_prn.c +0 -224
  3196. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_purp.c +0 -624
  3197. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_skey.c +0 -170
  3198. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.c +0 -1390
  3199. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +0 -89
  3200. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +0 -227
  3201. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +0 -280
  3202. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +0 -108
  3203. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.c +0 -86
  3204. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +0 -181
  3205. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -599
  3206. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +0 -206
  3207. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +0 -299
  3208. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +0 -240
  3209. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +0 -160
  3210. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +0 -189
  3211. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +0 -291
  3212. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +0 -1638
  3213. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +0 -440
  3214. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +0 -277
  3215. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +0 -407
  3216. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.c +0 -109
  3217. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +0 -133
  3218. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +0 -149
  3219. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +0 -356
  3220. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +0 -97
  3221. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +0 -384
  3222. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +0 -78
  3223. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +0 -527
  3224. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +0 -210
  3225. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.c +0 -116
  3226. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +0 -93
  3227. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +0 -79
  3228. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +0 -70
  3229. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +0 -544
  3230. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +0 -209
  3231. data/third_party/boringssl-with-bazel/src/gen/crypto/err_data.c +0 -1514
  3232. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/dilithium.h +0 -129
  3233. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/spx.h +0 -90
  3234. data/third_party/upb/upb/message/internal/compare_unknown.c +0 -289
  3235. data/third_party/upb/upb/message/internal/compare_unknown.h +0 -49
  3236. /data/src/core/{lib/gprpp → util}/glob.cc +0 -0
@@ -16,12 +16,15 @@
16
16
 
17
17
  #include "src/core/xds/xds_client/xds_client.h"
18
18
 
19
+ #include <grpc/event_engine/event_engine.h>
20
+ #include <grpc/support/port_platform.h>
19
21
  #include <inttypes.h>
20
22
  #include <string.h>
21
23
 
22
24
  #include <algorithm>
23
25
  #include <functional>
24
26
  #include <memory>
27
+ #include <optional>
25
28
  #include <string>
26
29
  #include <type_traits>
27
30
  #include <vector>
@@ -35,28 +38,27 @@
35
38
  #include "absl/strings/str_split.h"
36
39
  #include "absl/strings/string_view.h"
37
40
  #include "absl/strings/strip.h"
38
- #include "absl/types/optional.h"
39
41
  #include "envoy/config/core/v3/base.upb.h"
40
- #include "envoy/service/status/v3/csds.upb.h"
42
+ #include "envoy/service/discovery/v3/discovery.upb.h"
43
+ #include "envoy/service/discovery/v3/discovery.upbdefs.h"
41
44
  #include "google/protobuf/any.upb.h"
42
45
  #include "google/protobuf/timestamp.upb.h"
43
- #include "upb/base/string_view.h"
44
- #include "upb/mem/arena.h"
45
-
46
- #include <grpc/event_engine/event_engine.h>
47
- #include <grpc/support/port_platform.h>
48
-
49
- #include "src/core/lib/backoff/backoff.h"
50
- #include "src/core/lib/gprpp/debug_location.h"
51
- #include "src/core/lib/gprpp/orphanable.h"
52
- #include "src/core/lib/gprpp/ref_counted_ptr.h"
53
- #include "src/core/lib/gprpp/sync.h"
46
+ #include "google/rpc/status.upb.h"
54
47
  #include "src/core/lib/iomgr/exec_ctx.h"
55
- #include "src/core/lib/uri/uri_parser.h"
48
+ #include "src/core/util/backoff.h"
49
+ #include "src/core/util/debug_location.h"
50
+ #include "src/core/util/orphanable.h"
51
+ #include "src/core/util/ref_counted_ptr.h"
52
+ #include "src/core/util/sync.h"
56
53
  #include "src/core/util/upb_utils.h"
54
+ #include "src/core/util/uri.h"
57
55
  #include "src/core/xds/xds_client/xds_api.h"
58
56
  #include "src/core/xds/xds_client/xds_bootstrap.h"
59
- #include "src/core/xds/xds_client/xds_client_stats.h"
57
+ #include "src/core/xds/xds_client/xds_locality.h"
58
+ #include "upb/base/string_view.h"
59
+ #include "upb/mem/arena.h"
60
+ #include "upb/reflection/def.h"
61
+ #include "upb/text/encode.h"
60
62
 
61
63
  #define GRPC_XDS_INITIAL_CONNECT_BACKOFF_SECONDS 1
62
64
  #define GRPC_XDS_RECONNECT_BACKOFF_MULTIPLIER 1.6
@@ -74,6 +76,9 @@ using ::grpc_event_engine::experimental::EventEngine;
74
76
 
75
77
  // An xds call wrapper that can restart a call upon failure. Holds a ref to
76
78
  // the xds channel. The template parameter is the kind of wrapped xds call.
79
+ // TODO(roth): This is basically the same code as in LrsClient, and
80
+ // probably very similar to many other places in the codebase.
81
+ // Consider refactoring this into a common utility library somehow.
77
82
  template <typename T>
78
83
  class XdsClient::XdsChannel::RetryableCall final
79
84
  : public InternallyRefCounted<RetryableCall<T>> {
@@ -106,7 +111,7 @@ class XdsClient::XdsChannel::RetryableCall final
106
111
 
107
112
  // Retry state.
108
113
  BackOff backoff_;
109
- absl::optional<EventEngine::TaskHandle> timer_handle_
114
+ std::optional<EventEngine::TaskHandle> timer_handle_
110
115
  ABSL_GUARDED_BY(&XdsClient::mu_);
111
116
 
112
117
  bool shutting_down_ = false;
@@ -119,7 +124,10 @@ class XdsClient::XdsChannel::AdsCall final
119
124
  // The ctor and dtor should not be used directly.
120
125
  explicit AdsCall(RefCountedPtr<RetryableCall<AdsCall>> retryable_call);
121
126
 
122
- void Orphan() override;
127
+ // Disable thread-safety analysis because this method is called via
128
+ // OrphanablePtr<>, but there's no way to pass the lock annotation
129
+ // through there.
130
+ void Orphan() override ABSL_NO_THREAD_SAFETY_ANALYSIS;
123
131
 
124
132
  RetryableCall<AdsCall>* retryable_call() const {
125
133
  return retryable_call_.get();
@@ -140,44 +148,6 @@ class XdsClient::XdsChannel::AdsCall final
140
148
  private:
141
149
  class AdsReadDelayHandle;
142
150
 
143
- class AdsResponseParser final : public XdsApi::AdsResponseParserInterface {
144
- public:
145
- struct Result {
146
- const XdsResourceType* type;
147
- std::string type_url;
148
- std::string version;
149
- std::string nonce;
150
- std::vector<std::string> errors;
151
- std::map<std::string /*authority*/, std::set<XdsResourceKey>>
152
- resources_seen;
153
- uint64_t num_valid_resources = 0;
154
- uint64_t num_invalid_resources = 0;
155
- RefCountedPtr<ReadDelayHandle> read_delay_handle;
156
- };
157
-
158
- explicit AdsResponseParser(AdsCall* ads_call) : ads_call_(ads_call) {}
159
-
160
- absl::Status ProcessAdsResponseFields(AdsResponseFields fields) override
161
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
162
-
163
- void ParseResource(upb_Arena* arena, size_t idx, absl::string_view type_url,
164
- absl::string_view resource_name,
165
- absl::string_view serialized_resource) override
166
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
167
-
168
- void ResourceWrapperParsingFailed(size_t idx,
169
- absl::string_view message) override;
170
-
171
- Result TakeResult() { return std::move(result_); }
172
-
173
- private:
174
- XdsClient* xds_client() const { return ads_call_->xds_client(); }
175
-
176
- AdsCall* ads_call_;
177
- const Timestamp update_time_ = Timestamp::Now();
178
- Result result_;
179
- };
180
-
181
151
  class ResourceTimer final : public InternallyRefCounted<ResourceTimer> {
182
152
  public:
183
153
  ResourceTimer(const XdsResourceType* type, const XdsResourceName& name)
@@ -210,6 +180,7 @@ class XdsClient::XdsChannel::AdsCall final
210
180
  if (timer_handle_.has_value() &&
211
181
  ads_call_->xds_client()->engine()->Cancel(*timer_handle_)) {
212
182
  timer_handle_.reset();
183
+ ads_call_.reset();
213
184
  }
214
185
  }
215
186
 
@@ -236,40 +207,58 @@ class XdsClient::XdsChannel::AdsCall final
236
207
  // optimize by not resending the resource that we already have.
237
208
  auto& authority_state =
238
209
  ads_call->xds_client()->authority_state_map_[name_.authority];
239
- ResourceState& state = authority_state.resource_map[type_][name_.key];
240
- if (state.resource != nullptr) return;
210
+ ResourceState& state = authority_state.type_map[type_][name_.key];
211
+ if (state.HasResource()) return;
241
212
  // Start timer.
242
213
  ads_call_ = std::move(ads_call);
214
+ Duration timeout = ads_call_->xds_client()->request_timeout_;
215
+ if (timeout == Duration::Zero()) {
216
+ timeout = XdsDataErrorHandlingEnabled() &&
217
+ ads_call_->xds_channel()
218
+ ->server_.ResourceTimerIsTransientFailure()
219
+ ? Duration::Seconds(30)
220
+ : Duration::Seconds(15);
221
+ }
243
222
  timer_handle_ = ads_call_->xds_client()->engine()->RunAfter(
244
- ads_call_->xds_client()->request_timeout_,
245
- [self = Ref(DEBUG_LOCATION, "timer")]() {
246
- ApplicationCallbackExecCtx callback_exec_ctx;
223
+ timeout, [self = Ref(DEBUG_LOCATION, "timer")]() {
247
224
  ExecCtx exec_ctx;
248
225
  self->OnTimer();
249
226
  });
250
227
  }
251
228
 
252
229
  void OnTimer() {
253
- GRPC_TRACE_LOG(xds_client, INFO)
254
- << "[xds_client " << ads_call_->xds_client() << "] xds server "
255
- << ads_call_->xds_channel()->server_.server_uri()
256
- << ": timeout obtaining resource {type=" << type_->type_url()
257
- << " name="
258
- << XdsClient::ConstructFullXdsResourceName(
259
- name_.authority, type_->type_url(), name_.key)
260
- << "} from xds server";
261
230
  {
262
231
  MutexLock lock(&ads_call_->xds_client()->mu_);
263
232
  timer_handle_.reset();
264
- resource_seen_ = true;
265
233
  auto& authority_state =
266
234
  ads_call_->xds_client()->authority_state_map_[name_.authority];
267
- ResourceState& state = authority_state.resource_map[type_][name_.key];
268
- state.meta.client_status = XdsApi::ResourceMetadata::DOES_NOT_EXIST;
269
- ads_call_->xds_client()->NotifyWatchersOnResourceDoesNotExist(
270
- state.watchers, ReadDelayHandle::NoWait());
235
+ ResourceState& state = authority_state.type_map[type_][name_.key];
236
+ // We might have received the resource after the timer fired but before
237
+ // the callback ran.
238
+ if (!state.HasResource()) {
239
+ GRPC_TRACE_LOG(xds_client, INFO)
240
+ << "[xds_client " << ads_call_->xds_client() << "] xds server "
241
+ << ads_call_->xds_channel()->server_uri()
242
+ << ": timeout obtaining resource {type=" << type_->type_url()
243
+ << " name="
244
+ << XdsClient::ConstructFullXdsResourceName(
245
+ name_.authority, type_->type_url(), name_.key)
246
+ << "} from xds server";
247
+ resource_seen_ = true;
248
+ if (XdsDataErrorHandlingEnabled() &&
249
+ ads_call_->xds_channel()
250
+ ->server_.ResourceTimerIsTransientFailure()) {
251
+ state.SetTimeout(
252
+ absl::StrCat("timeout obtaining resource from xDS server ",
253
+ ads_call_->xds_channel()->server_uri()));
254
+ } else {
255
+ state.SetDoesNotExistOnTimeout();
256
+ }
257
+ ads_call_->xds_client()->NotifyWatchersOnResourceChanged(
258
+ state.failed_status(), state.watchers(),
259
+ ReadDelayHandle::NoWait());
260
+ }
271
261
  }
272
- ads_call_->xds_client()->work_serializer_.DrainQueue();
273
262
  ads_call_.reset();
274
263
  }
275
264
 
@@ -284,7 +273,7 @@ class XdsClient::XdsChannel::AdsCall final
284
273
  // stream or (b) declared the resource to not exist due to the timer
285
274
  // firing.
286
275
  bool resource_seen_ ABSL_GUARDED_BY(&XdsClient::mu_) = false;
287
- absl::optional<EventEngine::TaskHandle> timer_handle_
276
+ std::optional<EventEngine::TaskHandle> timer_handle_
288
277
  ABSL_GUARDED_BY(&XdsClient::mu_);
289
278
  };
290
279
 
@@ -317,9 +306,44 @@ class XdsClient::XdsChannel::AdsCall final
317
306
  subscribed_resources;
318
307
  };
319
308
 
309
+ std::string CreateAdsRequest(absl::string_view type_url,
310
+ absl::string_view version,
311
+ absl::string_view nonce,
312
+ const std::vector<std::string>& resource_names,
313
+ absl::Status status) const
314
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
315
+
320
316
  void SendMessageLocked(const XdsResourceType* type)
321
317
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
322
318
 
319
+ struct DecodeContext {
320
+ upb::Arena arena;
321
+ const XdsResourceType* type;
322
+ std::string type_url;
323
+ std::string version;
324
+ std::string nonce;
325
+ std::vector<std::string> errors;
326
+ std::map<std::string /*authority*/, std::set<XdsResourceKey>>
327
+ resources_seen;
328
+ uint64_t num_valid_resources = 0;
329
+ uint64_t num_invalid_resources = 0;
330
+ Timestamp update_time = Timestamp::Now();
331
+ RefCountedPtr<ReadDelayHandle> read_delay_handle;
332
+ };
333
+ void ParseResource(size_t idx, absl::string_view type_url,
334
+ absl::string_view resource_name,
335
+ absl::string_view serialized_resource,
336
+ DecodeContext* context)
337
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
338
+ void HandleServerReportedResourceError(size_t idx,
339
+ absl::string_view resource_name,
340
+ absl::Status status,
341
+ DecodeContext* context)
342
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
343
+ absl::Status DecodeAdsResponse(absl::string_view encoded_response,
344
+ DecodeContext* context)
345
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
346
+
323
347
  void OnRequestSent(bool ok);
324
348
  void OnRecvMessage(absl::string_view payload);
325
349
  void OnStatusReceived(absl::Status status);
@@ -350,98 +374,22 @@ class XdsClient::XdsChannel::AdsCall final
350
374
  std::map<const XdsResourceType*, ResourceTypeState> state_map_;
351
375
  };
352
376
 
353
- // Contains an LRS call to the xds server.
354
- class XdsClient::XdsChannel::LrsCall final
355
- : public InternallyRefCounted<LrsCall> {
356
- public:
357
- // The ctor and dtor should not be used directly.
358
- explicit LrsCall(RefCountedPtr<RetryableCall<LrsCall>> retryable_call);
377
+ //
378
+ // XdsClient::XdsChannel::ConnectivityFailureWatcher
379
+ //
359
380
 
360
- void Orphan() override;
381
+ class XdsClient::XdsChannel::ConnectivityFailureWatcher
382
+ : public XdsTransportFactory::XdsTransport::ConnectivityFailureWatcher {
383
+ public:
384
+ explicit ConnectivityFailureWatcher(WeakRefCountedPtr<XdsChannel> xds_channel)
385
+ : xds_channel_(std::move(xds_channel)) {}
361
386
 
362
- RetryableCall<LrsCall>* retryable_call() { return retryable_call_.get(); }
363
- XdsChannel* xds_channel() const { return retryable_call_->xds_channel(); }
364
- XdsClient* xds_client() const { return xds_channel()->xds_client(); }
365
- bool seen_response() const { return seen_response_; }
387
+ void OnConnectivityFailure(absl::Status status) override {
388
+ xds_channel_->OnConnectivityFailure(std::move(status));
389
+ }
366
390
 
367
391
  private:
368
- class StreamEventHandler final
369
- : public XdsTransportFactory::XdsTransport::StreamingCall::EventHandler {
370
- public:
371
- explicit StreamEventHandler(RefCountedPtr<LrsCall> lrs_call)
372
- : lrs_call_(std::move(lrs_call)) {}
373
-
374
- void OnRequestSent(bool /*ok*/) override { lrs_call_->OnRequestSent(); }
375
- void OnRecvMessage(absl::string_view payload) override {
376
- lrs_call_->OnRecvMessage(payload);
377
- }
378
- void OnStatusReceived(absl::Status status) override {
379
- lrs_call_->OnStatusReceived(std::move(status));
380
- }
381
-
382
- private:
383
- RefCountedPtr<LrsCall> lrs_call_;
384
- };
385
-
386
- // A repeating timer for a particular duration.
387
- class Timer final : public InternallyRefCounted<Timer> {
388
- public:
389
- explicit Timer(RefCountedPtr<LrsCall> lrs_call)
390
- : lrs_call_(std::move(lrs_call)) {}
391
- ~Timer() override { lrs_call_.reset(DEBUG_LOCATION, "LRS timer"); }
392
-
393
- // Disable thread-safety analysis because this method is called via
394
- // OrphanablePtr<>, but there's no way to pass the lock annotation
395
- // through there.
396
- void Orphan() override ABSL_NO_THREAD_SAFETY_ANALYSIS;
397
-
398
- void ScheduleNextReportLocked()
399
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
400
-
401
- private:
402
- bool IsCurrentTimerOnCall() const {
403
- return this == lrs_call_->timer_.get();
404
- }
405
- XdsClient* xds_client() const { return lrs_call_->xds_client(); }
406
-
407
- void OnNextReportTimer();
408
-
409
- // The owning LRS call.
410
- RefCountedPtr<LrsCall> lrs_call_;
411
-
412
- absl::optional<EventEngine::TaskHandle> timer_handle_
413
- ABSL_GUARDED_BY(&XdsClient::mu_);
414
- };
415
-
416
- void MaybeScheduleNextReportLocked()
417
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
418
-
419
- void SendReportLocked() ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
420
-
421
- void SendMessageLocked(std::string payload)
422
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
423
-
424
- void OnRequestSent();
425
- void OnRecvMessage(absl::string_view payload);
426
- void OnStatusReceived(absl::Status status);
427
-
428
- bool IsCurrentCallOnChannel() const;
429
-
430
- // The owning RetryableCall<>.
431
- RefCountedPtr<RetryableCall<LrsCall>> retryable_call_;
432
-
433
- OrphanablePtr<XdsTransportFactory::XdsTransport::StreamingCall>
434
- streaming_call_;
435
-
436
- bool seen_response_ = false;
437
- bool send_message_pending_ ABSL_GUARDED_BY(&XdsClient::mu_) = false;
438
-
439
- // Load reporting state.
440
- bool send_all_clusters_ = false;
441
- std::set<std::string> cluster_names_; // Asked for by the LRS server.
442
- Duration load_reporting_interval_;
443
- bool last_report_counters_were_zero_ = false;
444
- OrphanablePtr<Timer> timer_;
392
+ WeakRefCountedPtr<XdsChannel> xds_channel_;
445
393
  };
446
394
 
447
395
  //
@@ -457,23 +405,24 @@ XdsClient::XdsChannel::XdsChannel(WeakRefCountedPtr<XdsClient> xds_client,
457
405
  server_(server) {
458
406
  GRPC_TRACE_LOG(xds_client, INFO)
459
407
  << "[xds_client " << xds_client_.get() << "] creating channel " << this
460
- << " for server " << server.server_uri();
408
+ << " for server " << server_uri();
461
409
  absl::Status status;
462
- transport_ = xds_client_->transport_factory_->Create(
463
- server,
464
- [self = WeakRef(DEBUG_LOCATION, "OnConnectivityFailure")](
465
- absl::Status status) {
466
- self->OnConnectivityFailure(std::move(status));
467
- },
468
- &status);
410
+ transport_ =
411
+ xds_client_->transport_factory_->GetTransport(*server.target(), &status);
469
412
  CHECK(transport_ != nullptr);
470
- if (!status.ok()) SetChannelStatusLocked(std::move(status));
413
+ if (!status.ok()) {
414
+ SetChannelStatusLocked(std::move(status));
415
+ } else {
416
+ failure_watcher_ = MakeRefCounted<ConnectivityFailureWatcher>(
417
+ WeakRef(DEBUG_LOCATION, "OnConnectivityFailure"));
418
+ transport_->StartConnectivityFailureWatch(failure_watcher_);
419
+ }
471
420
  }
472
421
 
473
422
  XdsClient::XdsChannel::~XdsChannel() {
474
423
  GRPC_TRACE_LOG(xds_client, INFO)
475
424
  << "[xds_client " << xds_client() << "] destroying xds channel " << this
476
- << " for server " << server_.server_uri();
425
+ << " for server " << server_uri();
477
426
  xds_client_.reset(DEBUG_LOCATION, "XdsChannel");
478
427
  }
479
428
 
@@ -484,44 +433,28 @@ XdsClient::XdsChannel::~XdsChannel() {
484
433
  void XdsClient::XdsChannel::Orphaned() ABSL_NO_THREAD_SAFETY_ANALYSIS {
485
434
  GRPC_TRACE_LOG(xds_client, INFO)
486
435
  << "[xds_client " << xds_client() << "] orphaning xds channel " << this
487
- << " for server " << server_.server_uri();
436
+ << " for server " << server_uri();
488
437
  shutting_down_ = true;
438
+ if (failure_watcher_ != nullptr) {
439
+ transport_->StopConnectivityFailureWatch(failure_watcher_);
440
+ failure_watcher_.reset();
441
+ }
489
442
  transport_.reset();
490
443
  // At this time, all strong refs are removed, remove from channel map to
491
444
  // prevent subsequent subscription from trying to use this XdsChannel as
492
445
  // it is shutting down.
493
446
  xds_client_->xds_channel_map_.erase(server_.Key());
494
447
  ads_call_.reset();
495
- lrs_call_.reset();
496
448
  }
497
449
 
498
450
  void XdsClient::XdsChannel::ResetBackoff() { transport_->ResetBackoff(); }
499
451
 
500
- XdsClient::XdsChannel::AdsCall* XdsClient::XdsChannel::ads_call() const {
501
- return ads_call_->call();
502
- }
503
-
504
- XdsClient::XdsChannel::LrsCall* XdsClient::XdsChannel::lrs_call() const {
505
- return lrs_call_->call();
506
- }
507
-
508
- void XdsClient::XdsChannel::MaybeStartLrsCall() {
509
- if (lrs_call_ != nullptr) return;
510
- lrs_call_.reset(
511
- new RetryableCall<LrsCall>(WeakRef(DEBUG_LOCATION, "XdsChannel+lrs")));
512
- }
513
-
514
- void XdsClient::XdsChannel::StopLrsCallLocked() {
515
- xds_client_->xds_load_report_server_map_.erase(server_.Key());
516
- lrs_call_.reset();
517
- }
518
-
519
452
  void XdsClient::XdsChannel::SubscribeLocked(const XdsResourceType* type,
520
453
  const XdsResourceName& name) {
521
454
  if (ads_call_ == nullptr) {
522
455
  // Start the ADS call if this is the first request.
523
- ads_call_.reset(
524
- new RetryableCall<AdsCall>(WeakRef(DEBUG_LOCATION, "XdsChannel+ads")));
456
+ ads_call_ = MakeOrphanable<RetryableCall<AdsCall>>(
457
+ WeakRef(DEBUG_LOCATION, "XdsChannel+ads"));
525
458
  // Note: AdsCall's ctor will automatically subscribe to all
526
459
  // resources that the XdsClient already has watchers for, so we can
527
460
  // return here.
@@ -529,9 +462,9 @@ void XdsClient::XdsChannel::SubscribeLocked(const XdsResourceType* type,
529
462
  }
530
463
  // If the ADS call is in backoff state, we don't need to do anything now
531
464
  // because when the call is restarted it will resend all necessary requests.
532
- if (ads_call() == nullptr) return;
465
+ if (ads_call_->call() == nullptr) return;
533
466
  // Subscribe to this resource if the ADS call is active.
534
- ads_call()->SubscribeLocked(type, name, /*delay_send=*/false);
467
+ ads_call_->call()->SubscribeLocked(type, name, /*delay_send=*/false);
535
468
  }
536
469
 
537
470
  void XdsClient::XdsChannel::UnsubscribeLocked(const XdsResourceType* type,
@@ -544,6 +477,12 @@ void XdsClient::XdsChannel::UnsubscribeLocked(const XdsResourceType* type,
544
477
  if (!call->HasSubscribedResources()) {
545
478
  ads_call_.reset();
546
479
  }
480
+ } else {
481
+ // If there is currently no ADS call because we're in retry backoff,
482
+ // then we immediately trigger deletion of unsubscribed cache entries.
483
+ // This may orphan the XdsChannel, which would stop the retry
484
+ // timer, since we would no longer need to restart the ADS call.
485
+ xds_client_->MaybeRemoveUnsubscribedCacheEntriesForTypeLocked(this, type);
547
486
  }
548
487
  }
549
488
  }
@@ -563,16 +502,19 @@ bool XdsClient::XdsChannel::MaybeFallbackLocked(
563
502
  ++i) {
564
503
  authority_state.xds_channels.emplace_back(
565
504
  xds_client_->GetOrCreateXdsChannelLocked(*xds_servers[i], "fallback"));
566
- for (const auto& type_resource : authority_state.resource_map) {
567
- for (const auto& key_state : type_resource.second) {
568
- authority_state.xds_channels.back()->SubscribeLocked(
569
- type_resource.first, {authority, key_state.first});
505
+ for (const auto& [type, resource_map] : authority_state.type_map) {
506
+ for (const auto& [key, resource_state] : resource_map) {
507
+ if (resource_state.HasWatchers()) {
508
+ authority_state.xds_channels.back()->SubscribeLocked(
509
+ type, {authority, key});
510
+ }
570
511
  }
571
512
  }
572
513
  GRPC_TRACE_LOG(xds_client, INFO)
573
514
  << "[xds_client " << xds_client_.get() << "] authority " << authority
574
- << ": added fallback server " << xds_servers[i]->server_uri() << " ("
575
- << authority_state.xds_channels.back()->status().ToString() << ")";
515
+ << ": added fallback server " << xds_servers[i]->target()->server_uri()
516
+ << " (" << authority_state.xds_channels.back()->status().ToString()
517
+ << ")";
576
518
  if (authority_state.xds_channels.back()->status().ok()) return true;
577
519
  }
578
520
  GRPC_TRACE_LOG(xds_client, INFO)
@@ -587,77 +529,74 @@ void XdsClient::XdsChannel::SetHealthyLocked() {
587
529
  // 1. Channel is on the list of authority channels
588
530
  // 2. Channel is not the last channel on the list (i.e. not the active
589
531
  // channel)
590
- for (auto& authority : xds_client_->authority_state_map_) {
591
- auto& channels = authority.second.xds_channels;
532
+ for (auto& [authority, authority_state] : xds_client_->authority_state_map_) {
533
+ auto& channels = authority_state.xds_channels;
592
534
  // Skip if channel is active.
593
535
  if (channels.back() == this) continue;
594
536
  auto channel_it = std::find(channels.begin(), channels.end(), this);
595
537
  // Skip if this is not on the list
596
538
  if (channel_it != channels.end()) {
597
539
  GRPC_TRACE_LOG(xds_client, INFO)
598
- << "[xds_client " << xds_client_.get() << "] authority "
599
- << authority.first << ": Falling forward to " << server_.server_uri();
540
+ << "[xds_client " << xds_client_.get() << "] authority " << authority
541
+ << ": Falling forward to " << server_uri();
600
542
  // Lower priority channels are no longer needed, connection is back!
543
+ // Note that we move the lower priority channels out of the vector
544
+ // before we unref them, or else
545
+ // MaybeRemoveUnsubscribedCacheEntriesForTypeLocked() will try to
546
+ // access the vector while we are modifying it.
547
+ std::vector<RefCountedPtr<XdsChannel>> channels_to_unref(
548
+ std::make_move_iterator(channel_it + 1),
549
+ std::make_move_iterator(channels.end()));
601
550
  channels.erase(channel_it + 1, channels.end());
602
551
  }
603
552
  }
604
553
  }
605
554
 
606
555
  void XdsClient::XdsChannel::OnConnectivityFailure(absl::Status status) {
607
- {
608
- MutexLock lock(&xds_client_->mu_);
609
- SetChannelStatusLocked(std::move(status));
610
- }
611
- xds_client_->work_serializer_.DrainQueue();
556
+ MutexLock lock(&xds_client_->mu_);
557
+ SetChannelStatusLocked(std::move(status));
612
558
  }
613
559
 
614
560
  void XdsClient::XdsChannel::SetChannelStatusLocked(absl::Status status) {
615
561
  if (shutting_down_) return;
616
- status = absl::Status(status.code(), absl::StrCat("xDS channel for server ",
617
- server_.server_uri(), ": ",
618
- status.message()));
562
+ status = absl::Status(
563
+ status.code(), absl::StrCat("xDS channel for server ", server_uri(), ": ",
564
+ status.message()));
619
565
  LOG(INFO) << "[xds_client " << xds_client() << "] " << status;
620
- // If the node ID is set, append that to the status message that we send to
621
- // the watchers, so that it will appear in log messages visible to users.
622
- const auto* node = xds_client_->bootstrap_->node();
623
- if (node != nullptr) {
624
- status = absl::Status(
625
- status.code(),
626
- absl::StrCat(status.message(),
627
- " (node ID:", xds_client_->bootstrap_->node()->id(), ")"));
628
- }
629
566
  // If status was previously OK, report that the channel has gone unhealthy.
630
567
  if (status_.ok() && xds_client_->metrics_reporter_ != nullptr) {
631
- xds_client_->metrics_reporter_->ReportServerFailure(server_.server_uri());
568
+ xds_client_->metrics_reporter_->ReportServerFailure(server_uri());
632
569
  }
633
570
  // Save status in channel, so that we can immediately generate an
634
571
  // error for any new watchers that may be started.
635
572
  status_ = status;
636
573
  // Find all watchers for this channel.
637
- std::set<RefCountedPtr<ResourceWatcherInterface>> watchers;
638
- for (auto& a : xds_client_->authority_state_map_) { // authority
639
- if (a.second.xds_channels.empty() || a.second.xds_channels.back() != this ||
640
- MaybeFallbackLocked(a.first, a.second)) {
574
+ WatcherSet watchers_cached;
575
+ WatcherSet watchers_uncached;
576
+ for (auto& [authority, authority_state] : xds_client_->authority_state_map_) {
577
+ if (authority_state.xds_channels.empty() ||
578
+ authority_state.xds_channels.back() != this ||
579
+ MaybeFallbackLocked(authority, authority_state)) {
641
580
  continue;
642
581
  }
643
- for (const auto& t : a.second.resource_map) { // type
644
- for (const auto& r : t.second) { // resource id
645
- for (const auto& w : r.second.watchers) { // watchers
646
- watchers.insert(w.second);
582
+ for (const auto& [_, resource_map] : authority_state.type_map) {
583
+ for (const auto& [_, resource_state] : resource_map) {
584
+ auto& watchers =
585
+ resource_state.HasResource() ? watchers_cached : watchers_uncached;
586
+ for (const auto& watcher : resource_state.watchers()) {
587
+ watchers.insert(watcher);
647
588
  }
648
589
  }
649
590
  }
650
591
  }
651
- if (!watchers.empty()) {
652
- // Enqueue notification for the watchers.
653
- xds_client_->work_serializer_.Schedule(
654
- [watchers = std::move(watchers), status = std::move(status)]()
655
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(xds_client_->work_serializer_) {
656
- for (const auto& watcher : watchers) {
657
- watcher->OnError(status, ReadDelayHandle::NoWait());
658
- }
659
- },
660
- DEBUG_LOCATION);
592
+ // Enqueue notifications for the watchers.
593
+ if (!watchers_cached.empty()) {
594
+ xds_client_->NotifyWatchersOnAmbientError(
595
+ status, std::move(watchers_cached), ReadDelayHandle::NoWait());
596
+ }
597
+ if (!watchers_uncached.empty()) {
598
+ xds_client_->NotifyWatchersOnResourceChanged(
599
+ status, std::move(watchers_uncached), ReadDelayHandle::NoWait());
661
600
  }
662
601
  }
663
602
 
@@ -706,8 +645,8 @@ void XdsClient::XdsChannel::RetryableCall<T>::StartNewCallLocked() {
706
645
  CHECK(call_ == nullptr);
707
646
  GRPC_TRACE_LOG(xds_client, INFO)
708
647
  << "[xds_client " << xds_channel()->xds_client() << "] xds server "
709
- << xds_channel()->server_.server_uri()
710
- << ": start new call from retryable call " << this;
648
+ << xds_channel()->server_uri() << ": start new call from retryable call "
649
+ << this;
711
650
  call_ = MakeOrphanable<T>(
712
651
  this->Ref(DEBUG_LOCATION, "RetryableCall+start_new_call"));
713
652
  }
@@ -718,13 +657,12 @@ void XdsClient::XdsChannel::RetryableCall<T>::StartRetryTimerLocked() {
718
657
  const Duration delay = backoff_.NextAttemptDelay();
719
658
  GRPC_TRACE_LOG(xds_client, INFO)
720
659
  << "[xds_client " << xds_channel()->xds_client() << "] xds server "
721
- << xds_channel()->server_.server_uri()
660
+ << xds_channel()->server_uri()
722
661
  << ": call attempt failed; retry timer will fire in " << delay.millis()
723
662
  << "ms.";
724
663
  timer_handle_ = xds_channel()->xds_client()->engine()->RunAfter(
725
664
  delay,
726
665
  [self = this->Ref(DEBUG_LOCATION, "RetryableCall+retry_timer_start")]() {
727
- ApplicationCallbackExecCtx callback_exec_ctx;
728
666
  ExecCtx exec_ctx;
729
667
  self->OnRetryTimer();
730
668
  });
@@ -738,7 +676,7 @@ void XdsClient::XdsChannel::RetryableCall<T>::OnRetryTimer() {
738
676
  if (shutting_down_) return;
739
677
  GRPC_TRACE_LOG(xds_client, INFO)
740
678
  << "[xds_client " << xds_channel()->xds_client() << "] xds server "
741
- << xds_channel()->server_.server_uri()
679
+ << xds_channel()->server_uri()
742
680
  << ": retry timer fired (retryable call: " << this << ")";
743
681
  StartNewCallLocked();
744
682
  }
@@ -765,78 +703,273 @@ class XdsClient::XdsChannel::AdsCall::AdsReadDelayHandle final
765
703
  };
766
704
 
767
705
  //
768
- // XdsClient::XdsChannel::AdsCall::AdsResponseParser
706
+ // XdsClient::XdsChannel::AdsCall
769
707
  //
770
708
 
771
- absl::Status
772
- XdsClient::XdsChannel::AdsCall::AdsResponseParser::ProcessAdsResponseFields(
773
- AdsResponseFields fields) {
709
+ XdsClient::XdsChannel::AdsCall::AdsCall(
710
+ RefCountedPtr<RetryableCall<AdsCall>> retryable_call)
711
+ : InternallyRefCounted<AdsCall>(
712
+ GRPC_TRACE_FLAG_ENABLED(xds_client_refcount) ? "AdsCall" : nullptr),
713
+ retryable_call_(std::move(retryable_call)) {
714
+ CHECK_NE(xds_client(), nullptr);
715
+ // Init the ADS call.
716
+ const char* method =
717
+ "/envoy.service.discovery.v3.AggregatedDiscoveryService/"
718
+ "StreamAggregatedResources";
719
+ streaming_call_ = xds_channel()->transport_->CreateStreamingCall(
720
+ method, std::make_unique<StreamEventHandler>(
721
+ // Passing the initial ref here. This ref will go away when
722
+ // the StreamEventHandler is destroyed.
723
+ RefCountedPtr<AdsCall>(this)));
724
+ CHECK(streaming_call_ != nullptr);
725
+ // Start the call.
774
726
  GRPC_TRACE_LOG(xds_client, INFO)
775
- << "[xds_client " << ads_call_->xds_client() << "] xds server "
776
- << ads_call_->xds_channel()->server_.server_uri()
777
- << ": received ADS response: type_url=" << fields.type_url
778
- << ", version=" << fields.version << ", nonce=" << fields.nonce
779
- << ", num_resources=" << fields.num_resources;
780
- result_.type =
781
- ads_call_->xds_client()->GetResourceTypeLocked(fields.type_url);
782
- if (result_.type == nullptr) {
783
- return absl::InvalidArgumentError(
784
- absl::StrCat("unknown resource type ", fields.type_url));
727
+ << "[xds_client " << xds_client() << "] xds server "
728
+ << xds_channel()->server_uri()
729
+ << ": starting ADS call (ads_call: " << this
730
+ << ", streaming_call: " << streaming_call_.get() << ")";
731
+ // If this is a reconnect, add any necessary subscriptions from what's
732
+ // already in the cache.
733
+ for (auto& [authority, authority_state] :
734
+ xds_client()->authority_state_map_) {
735
+ auto it = std::find(authority_state.xds_channels.begin(),
736
+ authority_state.xds_channels.end(), xds_channel());
737
+ // Skip authorities that are not using this xDS channel. The channel can be
738
+ // anywhere in the list.
739
+ if (it == authority_state.xds_channels.end()) continue;
740
+ for (const auto& [type, resource_map] : authority_state.type_map) {
741
+ for (const auto& [resource_key, resource_state] : resource_map) {
742
+ if (resource_state.HasWatchers()) {
743
+ SubscribeLocked(type, {authority, resource_key}, /*delay_send=*/true);
744
+ }
745
+ }
746
+ }
785
747
  }
786
- result_.type_url = std::move(fields.type_url);
787
- result_.version = std::move(fields.version);
788
- result_.nonce = std::move(fields.nonce);
789
- result_.read_delay_handle =
790
- MakeRefCounted<AdsReadDelayHandle>(ads_call_->Ref());
791
- return absl::OkStatus();
748
+ // Send initial message if we added any subscriptions above.
749
+ for (const auto& [type, _] : state_map_) {
750
+ SendMessageLocked(type);
751
+ }
752
+ streaming_call_->StartRecvMessage();
753
+ }
754
+
755
+ void XdsClient::XdsChannel::AdsCall::Orphan() {
756
+ state_map_.clear();
757
+ // We may have unsubscriptions for which we have not yet actually sent
758
+ // unsubscribe messages, and now we never will, so do a pass to delete
759
+ // any cache entries for which we've unsubscribed.
760
+ for (const auto& [_, type] : xds_client()->resource_types_) {
761
+ xds_client()->MaybeRemoveUnsubscribedCacheEntriesForTypeLocked(
762
+ xds_channel(), type);
763
+ }
764
+ // Note that the initial ref is held by the StreamEventHandler, which
765
+ // will be destroyed when streaming_call_ is destroyed, which may not happen
766
+ // here, since there may be other refs held to streaming_call_ by internal
767
+ // callbacks.
768
+ streaming_call_.reset();
769
+ }
770
+
771
+ void XdsClient::XdsChannel::AdsCall::SubscribeLocked(
772
+ const XdsResourceType* type, const XdsResourceName& name, bool delay_send) {
773
+ auto& state = state_map_[type].subscribed_resources[name.authority][name.key];
774
+ if (state == nullptr) {
775
+ state = MakeOrphanable<ResourceTimer>(type, name);
776
+ if (!delay_send) SendMessageLocked(type);
777
+ }
778
+ }
779
+
780
+ void XdsClient::XdsChannel::AdsCall::UnsubscribeLocked(
781
+ const XdsResourceType* type, const XdsResourceName& name,
782
+ bool delay_unsubscription) {
783
+ auto& type_state_map = state_map_[type];
784
+ auto& authority_map = type_state_map.subscribed_resources[name.authority];
785
+ authority_map.erase(name.key);
786
+ if (authority_map.empty()) {
787
+ type_state_map.subscribed_resources.erase(name.authority);
788
+ // Note: We intentionally do not remove the top-level map entry for
789
+ // the resource type even if the authority map for the type is empty,
790
+ // because we need to retain the nonce in case a new watch is
791
+ // started for a resource of this type while this stream is still open.
792
+ }
793
+ // Don't need to send unsubscription message if this was the last
794
+ // resource we were subscribed to, since we'll be closing the stream
795
+ // immediately in that case.
796
+ if (!delay_unsubscription && HasSubscribedResources()) {
797
+ SendMessageLocked(type);
798
+ }
799
+ }
800
+
801
+ bool XdsClient::XdsChannel::AdsCall::HasSubscribedResources() const {
802
+ for (const auto& [_, resource_type_state] : state_map_) {
803
+ if (!resource_type_state.subscribed_resources.empty()) return true;
804
+ }
805
+ return false;
792
806
  }
793
807
 
794
808
  namespace {
795
809
 
796
- // Build a resource metadata struct for ADS result accepting methods and CSDS.
797
- XdsApi::ResourceMetadata CreateResourceMetadataAcked(
798
- std::string serialized_proto, std::string version, Timestamp update_time) {
799
- XdsApi::ResourceMetadata resource_metadata;
800
- resource_metadata.serialized_proto = std::move(serialized_proto);
801
- resource_metadata.update_time = update_time;
802
- resource_metadata.version = std::move(version);
803
- resource_metadata.client_status = XdsApi::ResourceMetadata::ACKED;
804
- return resource_metadata;
810
+ void MaybeLogDiscoveryRequest(
811
+ const XdsClient* client, upb_DefPool* def_pool,
812
+ const envoy_service_discovery_v3_DiscoveryRequest* request) {
813
+ if (GRPC_TRACE_FLAG_ENABLED(xds_client) && ABSL_VLOG_IS_ON(2)) {
814
+ const upb_MessageDef* msg_type =
815
+ envoy_service_discovery_v3_DiscoveryRequest_getmsgdef(def_pool);
816
+ char buf[10240];
817
+ upb_TextEncode(reinterpret_cast<const upb_Message*>(request), msg_type,
818
+ nullptr, 0, buf, sizeof(buf));
819
+ VLOG(2) << "[xds_client " << client << "] constructed ADS request: " << buf;
820
+ }
805
821
  }
806
822
 
807
- // Update resource_metadata for NACK.
808
- void UpdateResourceMetadataNacked(const std::string& version,
809
- const std::string& details,
810
- Timestamp update_time,
811
- XdsApi::ResourceMetadata* resource_metadata) {
812
- resource_metadata->client_status = XdsApi::ResourceMetadata::NACKED;
813
- resource_metadata->failed_version = version;
814
- resource_metadata->failed_details = details;
815
- resource_metadata->failed_update_time = update_time;
823
+ std::string SerializeDiscoveryRequest(
824
+ upb_Arena* arena, envoy_service_discovery_v3_DiscoveryRequest* request) {
825
+ size_t output_length;
826
+ char* output = envoy_service_discovery_v3_DiscoveryRequest_serialize(
827
+ request, arena, &output_length);
828
+ return std::string(output, output_length);
816
829
  }
817
830
 
818
831
  } // namespace
819
832
 
820
- void XdsClient::XdsChannel::AdsCall::AdsResponseParser::ParseResource(
821
- upb_Arena* arena, size_t idx, absl::string_view type_url,
822
- absl::string_view resource_name, absl::string_view serialized_resource) {
833
+ std::string XdsClient::XdsChannel::AdsCall::CreateAdsRequest(
834
+ absl::string_view type_url, absl::string_view version,
835
+ absl::string_view nonce, const std::vector<std::string>& resource_names,
836
+ absl::Status status) const {
837
+ upb::Arena arena;
838
+ // Create a request.
839
+ envoy_service_discovery_v3_DiscoveryRequest* request =
840
+ envoy_service_discovery_v3_DiscoveryRequest_new(arena.ptr());
841
+ // Set type_url.
842
+ std::string type_url_str = absl::StrCat("type.googleapis.com/", type_url);
843
+ envoy_service_discovery_v3_DiscoveryRequest_set_type_url(
844
+ request, StdStringToUpbString(type_url_str));
845
+ // Set version_info.
846
+ if (!version.empty()) {
847
+ envoy_service_discovery_v3_DiscoveryRequest_set_version_info(
848
+ request, StdStringToUpbString(version));
849
+ }
850
+ // Set nonce.
851
+ if (!nonce.empty()) {
852
+ envoy_service_discovery_v3_DiscoveryRequest_set_response_nonce(
853
+ request, StdStringToUpbString(nonce));
854
+ }
855
+ // Set error_detail if it's a NACK.
856
+ std::string error_string_storage;
857
+ if (!status.ok()) {
858
+ google_rpc_Status* error_detail =
859
+ envoy_service_discovery_v3_DiscoveryRequest_mutable_error_detail(
860
+ request, arena.ptr());
861
+ // Hard-code INVALID_ARGUMENT as the status code.
862
+ // TODO(roth): If at some point we decide we care about this value,
863
+ // we could attach a status code to the individual errors where we
864
+ // generate them in the parsing code, and then use that here.
865
+ google_rpc_Status_set_code(error_detail, GRPC_STATUS_INVALID_ARGUMENT);
866
+ // Error description comes from the status that was passed in.
867
+ error_string_storage = std::string(status.message());
868
+ upb_StringView error_description =
869
+ StdStringToUpbString(error_string_storage);
870
+ google_rpc_Status_set_message(error_detail, error_description);
871
+ }
872
+ // Populate node.
873
+ if (!sent_initial_message_) {
874
+ envoy_config_core_v3_Node* node_msg =
875
+ envoy_service_discovery_v3_DiscoveryRequest_mutable_node(request,
876
+ arena.ptr());
877
+ PopulateXdsNode(xds_client()->bootstrap_->node(),
878
+ xds_client()->user_agent_name_,
879
+ xds_client()->user_agent_version_, node_msg, arena.ptr());
880
+ envoy_config_core_v3_Node_add_client_features(
881
+ node_msg, upb_StringView_FromString("xds.config.resource-in-sotw"),
882
+ arena.ptr());
883
+ }
884
+ // Add resource_names.
885
+ for (const std::string& resource_name : resource_names) {
886
+ envoy_service_discovery_v3_DiscoveryRequest_add_resource_names(
887
+ request, StdStringToUpbString(resource_name), arena.ptr());
888
+ }
889
+ MaybeLogDiscoveryRequest(xds_client(), xds_client()->def_pool_.ptr(),
890
+ request);
891
+ return SerializeDiscoveryRequest(arena.ptr(), request);
892
+ }
893
+
894
+ void XdsClient::XdsChannel::AdsCall::SendMessageLocked(
895
+ const XdsResourceType* type)
896
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_) {
897
+ // Buffer message sending if an existing message is in flight.
898
+ if (send_message_pending_ != nullptr) {
899
+ buffered_requests_.insert(type);
900
+ return;
901
+ }
902
+ xds_client()->MaybeRemoveUnsubscribedCacheEntriesForTypeLocked(xds_channel(),
903
+ type);
904
+ auto& state = state_map_[type];
905
+ std::string serialized_message = CreateAdsRequest(
906
+ type->type_url(), xds_channel()->resource_type_version_map_[type],
907
+ state.nonce, ResourceNamesForRequest(type), state.status);
908
+ sent_initial_message_ = true;
909
+ GRPC_TRACE_LOG(xds_client, INFO)
910
+ << "[xds_client " << xds_client() << "] xds server "
911
+ << xds_channel()->server_uri()
912
+ << ": sending ADS request: type=" << type->type_url()
913
+ << " version=" << xds_channel()->resource_type_version_map_[type]
914
+ << " nonce=" << state.nonce << " error=" << state.status;
915
+ state.status = absl::OkStatus();
916
+ streaming_call_->SendMessage(std::move(serialized_message));
917
+ send_message_pending_ = type;
918
+ }
919
+
920
+ void XdsClient::XdsChannel::AdsCall::OnRequestSent(bool ok) {
921
+ MutexLock lock(&xds_client()->mu_);
922
+ // For each resource that was in the message we just sent, start the
923
+ // resource timer if needed.
924
+ if (ok) {
925
+ auto& resource_type_state = state_map_[send_message_pending_];
926
+ for (const auto& [_, resource_map] :
927
+ resource_type_state.subscribed_resources) {
928
+ for (auto& [_, resource_timer] : resource_map) {
929
+ resource_timer->MaybeMarkSubscriptionSendComplete(
930
+ Ref(DEBUG_LOCATION, "ResourceTimer"));
931
+ }
932
+ }
933
+ }
934
+ send_message_pending_ = nullptr;
935
+ if (ok && IsCurrentCallOnChannel()) {
936
+ // Continue to send another pending message if any.
937
+ // TODO(roth): The current code to handle buffered messages has the
938
+ // advantage of sending only the most recent list of resource names for
939
+ // each resource type (no matter how many times that resource type has
940
+ // been requested to send while the current message sending is still
941
+ // pending). But its disadvantage is that we send the requests in fixed
942
+ // order of resource types. We need to fix this if we are seeing some
943
+ // resource type(s) starved due to frequent requests of other resource
944
+ // type(s).
945
+ auto it = buffered_requests_.begin();
946
+ if (it != buffered_requests_.end()) {
947
+ SendMessageLocked(*it);
948
+ buffered_requests_.erase(it);
949
+ }
950
+ }
951
+ }
952
+
953
+ void XdsClient::XdsChannel::AdsCall::ParseResource(
954
+ size_t idx, absl::string_view type_url, absl::string_view resource_name,
955
+ absl::string_view serialized_resource, DecodeContext* context) {
823
956
  std::string error_prefix = absl::StrCat(
824
957
  "resource index ", idx, ": ",
825
958
  resource_name.empty() ? "" : absl::StrCat(resource_name, ": "));
826
959
  // Check the type_url of the resource.
827
- if (result_.type_url != type_url) {
828
- result_.errors.emplace_back(
960
+ if (context->type_url != type_url) {
961
+ context->errors.emplace_back(
829
962
  absl::StrCat(error_prefix, "incorrect resource type \"", type_url,
830
- "\" (should be \"", result_.type_url, "\")"));
831
- ++result_.num_invalid_resources;
963
+ "\" (should be \"", context->type_url, "\")"));
964
+ ++context->num_invalid_resources;
832
965
  return;
833
966
  }
834
967
  // Parse the resource.
835
- XdsResourceType::DecodeContext context = {
836
- xds_client(), ads_call_->xds_channel()->server_, &xds_client_trace,
837
- xds_client()->def_pool_.ptr(), arena};
968
+ XdsResourceType::DecodeContext resource_type_context = {
969
+ xds_client(), xds_channel()->server_, xds_client()->def_pool_.ptr(),
970
+ context->arena.ptr()};
838
971
  XdsResourceType::DecodeResult decode_result =
839
- result_.type->Decode(context, serialized_resource);
972
+ context->type->Decode(resource_type_context, serialized_resource);
840
973
  // If we didn't already have the resource name from the Resource
841
974
  // wrapper, try to get it from the decoding result.
842
975
  if (resource_name.empty()) {
@@ -847,35 +980,36 @@ void XdsClient::XdsChannel::AdsCall::AdsResponseParser::ParseResource(
847
980
  } else {
848
981
  // We don't have any way of determining the resource name, so
849
982
  // there's nothing more we can do here.
850
- result_.errors.emplace_back(absl::StrCat(
983
+ context->errors.emplace_back(absl::StrCat(
851
984
  error_prefix, decode_result.resource.status().ToString()));
852
- ++result_.num_invalid_resources;
985
+ ++context->num_invalid_resources;
853
986
  return;
854
987
  }
855
988
  }
856
989
  // If decoding failed, make sure we include the error in the NACK.
857
990
  const absl::Status& decode_status = decode_result.resource.status();
858
991
  if (!decode_status.ok()) {
859
- result_.errors.emplace_back(
992
+ context->errors.emplace_back(
860
993
  absl::StrCat(error_prefix, decode_status.ToString()));
861
994
  }
862
995
  // Check the resource name.
863
996
  auto parsed_resource_name =
864
- xds_client()->ParseXdsResourceName(resource_name, result_.type);
997
+ xds_client()->ParseXdsResourceName(resource_name, context->type);
865
998
  if (!parsed_resource_name.ok()) {
866
- result_.errors.emplace_back(
999
+ context->errors.emplace_back(
867
1000
  absl::StrCat(error_prefix, "Cannot parse xDS resource name"));
868
- ++result_.num_invalid_resources;
1001
+ ++context->num_invalid_resources;
869
1002
  return;
870
1003
  }
871
1004
  // Cancel resource-does-not-exist timer, if needed.
872
- auto timer_it = ads_call_->state_map_.find(result_.type);
873
- if (timer_it != ads_call_->state_map_.end()) {
874
- auto it = timer_it->second.subscribed_resources.find(
1005
+ if (auto it = state_map_.find(context->type); it != state_map_.end()) {
1006
+ auto& resource_type_state = it->second;
1007
+ auto authority_it = resource_type_state.subscribed_resources.find(
875
1008
  parsed_resource_name->authority);
876
- if (it != timer_it->second.subscribed_resources.end()) {
877
- auto res_it = it->second.find(parsed_resource_name->key);
878
- if (res_it != it->second.end()) {
1009
+ if (authority_it != resource_type_state.subscribed_resources.end()) {
1010
+ auto& resource_map = authority_it->second;
1011
+ auto res_it = resource_map.find(parsed_resource_name->key);
1012
+ if (res_it != resource_map.end()) {
879
1013
  res_it->second->MarkSeen();
880
1014
  }
881
1015
  }
@@ -886,366 +1020,397 @@ void XdsClient::XdsChannel::AdsCall::AdsResponseParser::ParseResource(
886
1020
  if (authority_it == xds_client()->authority_state_map_.end()) {
887
1021
  return; // Skip resource -- we don't have a subscription for it.
888
1022
  }
889
- // Found authority, so look up type.
890
1023
  AuthorityState& authority_state = authority_it->second;
891
- auto type_it = authority_state.resource_map.find(result_.type);
892
- if (type_it == authority_state.resource_map.end()) {
1024
+ // Found authority, so look up type.
1025
+ auto type_it = authority_state.type_map.find(context->type);
1026
+ if (type_it == authority_state.type_map.end()) {
893
1027
  return; // Skip resource -- we don't have a subscription for it.
894
1028
  }
895
1029
  auto& type_map = type_it->second;
896
1030
  // Found type, so look up resource key.
897
- auto it = type_map.find(parsed_resource_name->key);
898
- if (it == type_map.end()) {
1031
+ auto res_it = type_map.find(parsed_resource_name->key);
1032
+ if (res_it == type_map.end()) {
899
1033
  return; // Skip resource -- we don't have a subscription for it.
900
1034
  }
901
- ResourceState& resource_state = it->second;
1035
+ ResourceState& resource_state = res_it->second;
902
1036
  // If needed, record that we've seen this resource.
903
- if (result_.type->AllResourcesRequiredInSotW()) {
904
- result_.resources_seen[parsed_resource_name->authority].insert(
1037
+ if (context->type->AllResourcesRequiredInSotW()) {
1038
+ context->resources_seen[parsed_resource_name->authority].insert(
905
1039
  parsed_resource_name->key);
906
1040
  }
907
- // If we previously ignored the resource's deletion, log that we're
908
- // now re-adding it.
909
- if (resource_state.ignored_deletion) {
910
- LOG(INFO) << "[xds_client " << xds_client() << "] xds server "
911
- << ads_call_->xds_channel()->server_.server_uri()
912
- << ": server returned new version of resource for which we "
913
- "previously ignored a deletion: type "
914
- << type_url << " name " << resource_name;
915
- resource_state.ignored_deletion = false;
916
- }
917
1041
  // Update resource state based on whether the resource is valid.
918
1042
  if (!decode_status.ok()) {
919
- xds_client()->NotifyWatchersOnErrorLocked(
920
- resource_state.watchers,
921
- absl::UnavailableError(
922
- absl::StrCat("invalid resource: ", decode_status.ToString())),
923
- result_.read_delay_handle);
924
- UpdateResourceMetadataNacked(result_.version, decode_status.ToString(),
925
- update_time_, &resource_state.meta);
926
- ++result_.num_invalid_resources;
1043
+ ++context->num_invalid_resources;
1044
+ // If the fail_on_data_errors server feature is present, drop the
1045
+ // existing cached resource, if any.
1046
+ const bool drop_cached_resource = XdsDataErrorHandlingEnabled() &&
1047
+ xds_channel()->server_.FailOnDataErrors();
1048
+ resource_state.SetNacked(context->version, decode_status.message(),
1049
+ context->update_time, drop_cached_resource);
1050
+ xds_client()->NotifyWatchersOnError(resource_state,
1051
+ context->read_delay_handle);
927
1052
  return;
928
1053
  }
929
1054
  // Resource is valid.
930
- ++result_.num_valid_resources;
931
- // If it didn't change, ignore it.
932
- if (resource_state.resource != nullptr &&
933
- result_.type->ResourcesEqual(resource_state.resource.get(),
934
- decode_result.resource->get())) {
1055
+ ++context->num_valid_resources;
1056
+ // Check if the resource has changed.
1057
+ const bool resource_identical =
1058
+ resource_state.HasResource() &&
1059
+ context->type->ResourcesEqual(resource_state.resource().get(),
1060
+ decode_result.resource->get());
1061
+ // If not changed, keep using the current decoded resource object.
1062
+ // This should avoid wasting memory, since external watchers may be
1063
+ // holding refs to the current object.
1064
+ if (resource_identical) decode_result.resource = resource_state.resource();
1065
+ // Update the resource state.
1066
+ resource_state.SetAcked(std::move(*decode_result.resource),
1067
+ std::string(serialized_resource), context->version,
1068
+ context->update_time);
1069
+ // If the resource didn't change, inhibit watcher notifications.
1070
+ if (resource_identical) {
935
1071
  GRPC_TRACE_LOG(xds_client, INFO)
936
- << "[xds_client " << xds_client() << "] " << result_.type_url
1072
+ << "[xds_client " << xds_client() << "] " << context->type_url
937
1073
  << " resource " << resource_name << " identical to current, ignoring.";
1074
+ // If we previously had connectivity problems, notify watchers that
1075
+ // the ambient error has been cleared.
1076
+ if (!xds_channel()->status().ok()) {
1077
+ xds_client()->NotifyWatchersOnAmbientError(absl::OkStatus(),
1078
+ resource_state.watchers(),
1079
+ context->read_delay_handle);
1080
+ }
938
1081
  return;
939
1082
  }
940
- // Update the resource state.
941
- resource_state.resource = std::move(*decode_result.resource);
942
- resource_state.meta = CreateResourceMetadataAcked(
943
- std::string(serialized_resource), result_.version, update_time_);
944
1083
  // Notify watchers.
945
- auto& watchers_list = resource_state.watchers;
946
- xds_client()->work_serializer_.Schedule(
947
- [watchers_list, value = resource_state.resource,
948
- read_delay_handle = result_.read_delay_handle]()
949
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&xds_client()->work_serializer_) {
950
- for (const auto& p : watchers_list) {
951
- p.first->OnGenericResourceChanged(value, read_delay_handle);
952
- }
953
- },
954
- DEBUG_LOCATION);
955
- }
956
-
957
- void XdsClient::XdsChannel::AdsCall::AdsResponseParser::
958
- ResourceWrapperParsingFailed(size_t idx, absl::string_view message) {
959
- result_.errors.emplace_back(
960
- absl::StrCat("resource index ", idx, ": ", message));
961
- ++result_.num_invalid_resources;
1084
+ xds_client()->NotifyWatchersOnResourceChanged(resource_state.resource(),
1085
+ resource_state.watchers(),
1086
+ context->read_delay_handle);
962
1087
  }
963
1088
 
964
- //
965
- // XdsClient::XdsChannel::AdsCall
966
- //
967
-
968
- XdsClient::XdsChannel::AdsCall::AdsCall(
969
- RefCountedPtr<RetryableCall<AdsCall>> retryable_call)
970
- : InternallyRefCounted<AdsCall>(
971
- GRPC_TRACE_FLAG_ENABLED(xds_client_refcount) ? "AdsCall" : nullptr),
972
- retryable_call_(std::move(retryable_call)) {
973
- CHECK_NE(xds_client(), nullptr);
974
- // Init the ADS call.
975
- const char* method =
976
- "/envoy.service.discovery.v3.AggregatedDiscoveryService/"
977
- "StreamAggregatedResources";
978
- streaming_call_ = xds_channel()->transport_->CreateStreamingCall(
979
- method, std::make_unique<StreamEventHandler>(
980
- // Passing the initial ref here. This ref will go away when
981
- // the StreamEventHandler is destroyed.
982
- RefCountedPtr<AdsCall>(this)));
983
- CHECK(streaming_call_ != nullptr);
984
- // Start the call.
985
- GRPC_TRACE_LOG(xds_client, INFO)
986
- << "[xds_client " << xds_client() << "] xds server "
987
- << xds_channel()->server_.server_uri()
988
- << ": starting ADS call (ads_call: " << this
989
- << ", streaming_call: " << streaming_call_.get() << ")";
990
- // If this is a reconnect, add any necessary subscriptions from what's
991
- // already in the cache.
992
- for (auto& a : xds_client()->authority_state_map_) {
993
- const std::string& authority = a.first;
994
- auto it = std::find(a.second.xds_channels.begin(),
995
- a.second.xds_channels.end(), xds_channel());
996
- // Skip authorities that are not using this xDS channel. The channel can be
997
- // anywhere in the list.
998
- if (it == a.second.xds_channels.end()) continue;
999
- for (const auto& t : a.second.resource_map) {
1000
- const XdsResourceType* type = t.first;
1001
- for (const auto& r : t.second) {
1002
- const XdsResourceKey& resource_key = r.first;
1003
- SubscribeLocked(type, {authority, resource_key}, /*delay_send=*/true);
1089
+ void XdsClient::XdsChannel::AdsCall::HandleServerReportedResourceError(
1090
+ size_t idx, absl::string_view resource_name, absl::Status status,
1091
+ DecodeContext* context) {
1092
+ std::string error_prefix = absl::StrCat(
1093
+ "resource_errors index ", idx, ": ",
1094
+ resource_name.empty() ? "" : absl::StrCat(resource_name, ": "));
1095
+ if (resource_name.empty()) {
1096
+ context->errors.emplace_back(
1097
+ absl::StrCat(error_prefix, "resource_name unset"));
1098
+ ++context->num_invalid_resources;
1099
+ return;
1100
+ }
1101
+ if (status.ok()) {
1102
+ context->errors.emplace_back(
1103
+ absl::StrCat(error_prefix, "error_detail must be non-OK"));
1104
+ ++context->num_invalid_resources;
1105
+ return;
1106
+ }
1107
+ // Check the resource name.
1108
+ auto parsed_resource_name =
1109
+ xds_client()->ParseXdsResourceName(resource_name, context->type);
1110
+ if (!parsed_resource_name.ok()) {
1111
+ context->errors.emplace_back(
1112
+ absl::StrCat(error_prefix, "Cannot parse xDS resource name"));
1113
+ ++context->num_invalid_resources;
1114
+ return;
1115
+ }
1116
+ // Cancel resource-does-not-exist timer, if needed.
1117
+ auto timer_it = state_map_.find(context->type);
1118
+ if (timer_it != state_map_.end()) {
1119
+ auto it = timer_it->second.subscribed_resources.find(
1120
+ parsed_resource_name->authority);
1121
+ if (it != timer_it->second.subscribed_resources.end()) {
1122
+ auto res_it = it->second.find(parsed_resource_name->key);
1123
+ if (res_it != it->second.end()) {
1124
+ res_it->second->MarkSeen();
1004
1125
  }
1005
1126
  }
1006
1127
  }
1007
- // Send initial message if we added any subscriptions above.
1008
- for (const auto& p : state_map_) {
1009
- SendMessageLocked(p.first);
1128
+ // Lookup the authority in the cache.
1129
+ auto authority_it =
1130
+ xds_client()->authority_state_map_.find(parsed_resource_name->authority);
1131
+ if (authority_it == xds_client()->authority_state_map_.end()) {
1132
+ return; // Skip resource -- we don't have a subscription for it.
1010
1133
  }
1011
- streaming_call_->StartRecvMessage();
1012
- }
1013
-
1014
- void XdsClient::XdsChannel::AdsCall::Orphan() {
1015
- state_map_.clear();
1016
- // Note that the initial ref is held by the StreamEventHandler, which
1017
- // will be destroyed when streaming_call_ is destroyed, which may not happen
1018
- // here, since there may be other refs held to streaming_call_ by internal
1019
- // callbacks.
1020
- streaming_call_.reset();
1021
- }
1022
-
1023
- void XdsClient::XdsChannel::AdsCall::SendMessageLocked(
1024
- const XdsResourceType* type)
1025
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_) {
1026
- // Buffer message sending if an existing message is in flight.
1027
- if (send_message_pending_ != nullptr) {
1028
- buffered_requests_.insert(type);
1029
- return;
1134
+ AuthorityState& authority_state = authority_it->second;
1135
+ // Found authority, so look up type.
1136
+ auto type_it = authority_state.type_map.find(context->type);
1137
+ if (type_it == authority_state.type_map.end()) {
1138
+ return; // Skip resource -- we don't have a subscription for it.
1030
1139
  }
1031
- auto& state = state_map_[type];
1032
- std::string serialized_message = xds_client()->api_.CreateAdsRequest(
1033
- type->type_url(), xds_channel()->resource_type_version_map_[type],
1034
- state.nonce, ResourceNamesForRequest(type), state.status,
1035
- !sent_initial_message_);
1036
- sent_initial_message_ = true;
1037
- GRPC_TRACE_LOG(xds_client, INFO)
1038
- << "[xds_client " << xds_client() << "] xds server "
1039
- << xds_channel()->server_.server_uri()
1040
- << ": sending ADS request: type=" << type->type_url()
1041
- << " version=" << xds_channel()->resource_type_version_map_[type]
1042
- << " nonce=" << state.nonce << " error=" << state.status;
1043
- state.status = absl::OkStatus();
1044
- streaming_call_->SendMessage(std::move(serialized_message));
1045
- send_message_pending_ = type;
1046
- }
1047
-
1048
- void XdsClient::XdsChannel::AdsCall::SubscribeLocked(
1049
- const XdsResourceType* type, const XdsResourceName& name, bool delay_send) {
1050
- auto& state = state_map_[type].subscribed_resources[name.authority][name.key];
1051
- if (state == nullptr) {
1052
- state = MakeOrphanable<ResourceTimer>(type, name);
1053
- if (!delay_send) SendMessageLocked(type);
1140
+ auto& type_map = type_it->second;
1141
+ // Found type, so look up resource key.
1142
+ auto it = type_map.find(parsed_resource_name->key);
1143
+ if (it == type_map.end()) {
1144
+ return; // Skip resource -- we don't have a subscription for it.
1054
1145
  }
1055
- }
1056
-
1057
- void XdsClient::XdsChannel::AdsCall::UnsubscribeLocked(
1058
- const XdsResourceType* type, const XdsResourceName& name,
1059
- bool delay_unsubscription) {
1060
- auto& type_state_map = state_map_[type];
1061
- auto& authority_map = type_state_map.subscribed_resources[name.authority];
1062
- authority_map.erase(name.key);
1063
- if (authority_map.empty()) {
1064
- type_state_map.subscribed_resources.erase(name.authority);
1146
+ ResourceState& resource_state = it->second;
1147
+ // If needed, record that we've seen this resource.
1148
+ if (context->type->AllResourcesRequiredInSotW()) {
1149
+ context->resources_seen[parsed_resource_name->authority].insert(
1150
+ parsed_resource_name->key);
1065
1151
  }
1066
- // Don't need to send unsubscription message if this was the last
1067
- // resource we were subscribed to, since we'll be closing the stream
1068
- // immediately in that case.
1069
- if (!delay_unsubscription && HasSubscribedResources()) {
1070
- SendMessageLocked(type);
1152
+ ++context->num_invalid_resources;
1153
+ // Update cache state.
1154
+ const bool drop_cached_resource =
1155
+ xds_channel()->server_.FailOnDataErrors() &&
1156
+ (status.code() == absl::StatusCode::kNotFound ||
1157
+ status.code() == absl::StatusCode::kPermissionDenied);
1158
+ resource_state.SetReceivedError(context->version, std::move(status),
1159
+ context->update_time, drop_cached_resource);
1160
+ // If there is no cached resource (either because we didn't have one
1161
+ // or because we just dropped it due to fail_on_data_errors), then notify
1162
+ // via OnResourceChanged(); otherwise, notify via OnAmbientError().
1163
+ if (!resource_state.HasResource()) {
1164
+ xds_client()->NotifyWatchersOnResourceChanged(
1165
+ resource_state.failed_status(), resource_state.watchers(),
1166
+ context->read_delay_handle);
1167
+ } else {
1168
+ xds_client()->NotifyWatchersOnAmbientError(resource_state.failed_status(),
1169
+ resource_state.watchers(),
1170
+ context->read_delay_handle);
1071
1171
  }
1072
1172
  }
1073
1173
 
1074
- bool XdsClient::XdsChannel::AdsCall::HasSubscribedResources() const {
1075
- for (const auto& p : state_map_) {
1076
- if (!p.second.subscribed_resources.empty()) return true;
1174
+ namespace {
1175
+
1176
+ void MaybeLogDiscoveryResponse(
1177
+ const XdsClient* client, upb_DefPool* def_pool,
1178
+ const envoy_service_discovery_v3_DiscoveryResponse* response) {
1179
+ if (GRPC_TRACE_FLAG_ENABLED(xds_client) && ABSL_VLOG_IS_ON(2)) {
1180
+ const upb_MessageDef* msg_type =
1181
+ envoy_service_discovery_v3_DiscoveryResponse_getmsgdef(def_pool);
1182
+ char buf[10240];
1183
+ upb_TextEncode(reinterpret_cast<const upb_Message*>(response), msg_type,
1184
+ nullptr, 0, buf, sizeof(buf));
1185
+ VLOG(2) << "[xds_client " << client << "] received response: " << buf;
1077
1186
  }
1078
- return false;
1079
1187
  }
1080
1188
 
1081
- void XdsClient::XdsChannel::AdsCall::OnRequestSent(bool ok) {
1082
- MutexLock lock(&xds_client()->mu_);
1083
- // For each resource that was in the message we just sent, start the
1084
- // resource timer if needed.
1085
- if (ok) {
1086
- auto& resource_type_state = state_map_[send_message_pending_];
1087
- for (const auto& p : resource_type_state.subscribed_resources) {
1088
- for (auto& q : p.second) {
1089
- q.second->MaybeMarkSubscriptionSendComplete(
1090
- Ref(DEBUG_LOCATION, "ResourceTimer"));
1189
+ } // namespace
1190
+
1191
+ absl::Status XdsClient::XdsChannel::AdsCall::DecodeAdsResponse(
1192
+ absl::string_view encoded_response, DecodeContext* context) {
1193
+ // Decode the response.
1194
+ const envoy_service_discovery_v3_DiscoveryResponse* response =
1195
+ envoy_service_discovery_v3_DiscoveryResponse_parse(
1196
+ encoded_response.data(), encoded_response.size(),
1197
+ context->arena.ptr());
1198
+ // If decoding fails, report a fatal error and return.
1199
+ if (response == nullptr) {
1200
+ return absl::InvalidArgumentError("Can't decode DiscoveryResponse.");
1201
+ }
1202
+ MaybeLogDiscoveryResponse(xds_client(), xds_client()->def_pool_.ptr(),
1203
+ response);
1204
+ // Get the type_url, version, nonce, number of resources, and number
1205
+ // of errors.
1206
+ context->type_url = std::string(absl::StripPrefix(
1207
+ UpbStringToAbsl(
1208
+ envoy_service_discovery_v3_DiscoveryResponse_type_url(response)),
1209
+ "type.googleapis.com/"));
1210
+ context->version = UpbStringToStdString(
1211
+ envoy_service_discovery_v3_DiscoveryResponse_version_info(response));
1212
+ context->nonce = UpbStringToStdString(
1213
+ envoy_service_discovery_v3_DiscoveryResponse_nonce(response));
1214
+ size_t num_resources;
1215
+ const google_protobuf_Any* const* resources =
1216
+ envoy_service_discovery_v3_DiscoveryResponse_resources(response,
1217
+ &num_resources);
1218
+ size_t num_errors = 0;
1219
+ const envoy_service_discovery_v3_ResourceError* const* errors = nullptr;
1220
+ if (XdsDataErrorHandlingEnabled()) {
1221
+ errors = envoy_service_discovery_v3_DiscoveryResponse_resource_errors(
1222
+ response, &num_errors);
1223
+ }
1224
+ GRPC_TRACE_LOG(xds_client, INFO)
1225
+ << "[xds_client " << xds_client() << "] xds server "
1226
+ << xds_channel()->server_uri()
1227
+ << ": received ADS response: type_url=" << context->type_url
1228
+ << ", version=" << context->version << ", nonce=" << context->nonce
1229
+ << ", num_resources=" << num_resources << ", num_errors=" << num_errors;
1230
+ context->type = xds_client()->GetResourceTypeLocked(context->type_url);
1231
+ if (context->type == nullptr) {
1232
+ return absl::InvalidArgumentError(
1233
+ absl::StrCat("unknown resource type ", context->type_url));
1234
+ }
1235
+ context->read_delay_handle = MakeRefCounted<AdsReadDelayHandle>(Ref());
1236
+ // Process each resource.
1237
+ for (size_t i = 0; i < num_resources; ++i) {
1238
+ absl::string_view type_url = absl::StripPrefix(
1239
+ UpbStringToAbsl(google_protobuf_Any_type_url(resources[i])),
1240
+ "type.googleapis.com/");
1241
+ absl::string_view serialized_resource =
1242
+ UpbStringToAbsl(google_protobuf_Any_value(resources[i]));
1243
+ // Unwrap Resource messages, if so wrapped.
1244
+ absl::string_view resource_name;
1245
+ if (type_url == "envoy.service.discovery.v3.Resource") {
1246
+ const auto* resource_wrapper = envoy_service_discovery_v3_Resource_parse(
1247
+ serialized_resource.data(), serialized_resource.size(),
1248
+ context->arena.ptr());
1249
+ if (resource_wrapper == nullptr) {
1250
+ context->errors.emplace_back(absl::StrCat(
1251
+ "resource index ", i, ": Can't decode Resource proto wrapper"));
1252
+ ++context->num_invalid_resources;
1253
+ continue;
1091
1254
  }
1255
+ const auto* resource =
1256
+ envoy_service_discovery_v3_Resource_resource(resource_wrapper);
1257
+ if (resource == nullptr) {
1258
+ context->errors.emplace_back(
1259
+ absl::StrCat("resource index ", i,
1260
+ ": No resource present in Resource proto wrappe"));
1261
+ ++context->num_invalid_resources;
1262
+ continue;
1263
+ }
1264
+ type_url = absl::StripPrefix(
1265
+ UpbStringToAbsl(google_protobuf_Any_type_url(resource)),
1266
+ "type.googleapis.com/");
1267
+ serialized_resource =
1268
+ UpbStringToAbsl(google_protobuf_Any_value(resource));
1269
+ resource_name = UpbStringToAbsl(
1270
+ envoy_service_discovery_v3_Resource_name(resource_wrapper));
1092
1271
  }
1272
+ ParseResource(i, type_url, resource_name, serialized_resource, context);
1093
1273
  }
1094
- send_message_pending_ = nullptr;
1095
- if (ok && IsCurrentCallOnChannel()) {
1096
- // Continue to send another pending message if any.
1097
- // TODO(roth): The current code to handle buffered messages has the
1098
- // advantage of sending only the most recent list of resource names for
1099
- // each resource type (no matter how many times that resource type has
1100
- // been requested to send while the current message sending is still
1101
- // pending). But its disadvantage is that we send the requests in fixed
1102
- // order of resource types. We need to fix this if we are seeing some
1103
- // resource type(s) starved due to frequent requests of other resource
1104
- // type(s).
1105
- auto it = buffered_requests_.begin();
1106
- if (it != buffered_requests_.end()) {
1107
- SendMessageLocked(*it);
1108
- buffered_requests_.erase(it);
1274
+ // Process each error.
1275
+ for (size_t i = 0; i < num_errors; ++i) {
1276
+ absl::string_view name;
1277
+ {
1278
+ const envoy_service_discovery_v3_ResourceName* resource_name =
1279
+ envoy_service_discovery_v3_ResourceError_resource_name(errors[i]);
1280
+ if (resource_name != nullptr) {
1281
+ name = UpbStringToAbsl(
1282
+ envoy_service_discovery_v3_ResourceName_name(resource_name));
1283
+ }
1109
1284
  }
1285
+ absl::Status status;
1286
+ {
1287
+ const google_rpc_Status* error_detail =
1288
+ envoy_service_discovery_v3_ResourceError_error_detail(errors[i]);
1289
+ if (error_detail != nullptr) {
1290
+ status = absl::Status(
1291
+ static_cast<absl::StatusCode>(google_rpc_Status_code(error_detail)),
1292
+ UpbStringToAbsl(google_rpc_Status_message(error_detail)));
1293
+ }
1294
+ }
1295
+ HandleServerReportedResourceError(i, name, std::move(status), context);
1110
1296
  }
1297
+ return absl::OkStatus();
1111
1298
  }
1112
1299
 
1113
1300
  void XdsClient::XdsChannel::AdsCall::OnRecvMessage(absl::string_view payload) {
1114
- // Needs to be destroyed after the mutex is released.
1115
- RefCountedPtr<ReadDelayHandle> read_delay_handle;
1116
- {
1117
- MutexLock lock(&xds_client()->mu_);
1118
- if (!IsCurrentCallOnChannel()) return;
1119
- // Parse and validate the response.
1120
- AdsResponseParser parser(this);
1121
- absl::Status status = xds_client()->api_.ParseAdsResponse(payload, &parser);
1122
- // This includes a handle that will trigger an ADS read.
1123
- AdsResponseParser::Result result = parser.TakeResult();
1124
- read_delay_handle = std::move(result.read_delay_handle);
1125
- if (!status.ok()) {
1126
- // Ignore unparsable response.
1301
+ // context.read_delay_handle needs to be destroyed after the mutex is
1302
+ // released.
1303
+ DecodeContext context;
1304
+ MutexLock lock(&xds_client()->mu_);
1305
+ if (!IsCurrentCallOnChannel()) return;
1306
+ // Parse and validate the response.
1307
+ absl::Status status = DecodeAdsResponse(payload, &context);
1308
+ if (!status.ok()) {
1309
+ // Ignore unparsable response.
1310
+ LOG(ERROR) << "[xds_client " << xds_client() << "] xds server "
1311
+ << xds_channel()->server_uri()
1312
+ << ": error parsing ADS response (" << status << ") -- ignoring";
1313
+ } else {
1314
+ seen_response_ = true;
1315
+ xds_channel()->SetHealthyLocked();
1316
+ // Update nonce.
1317
+ auto& state = state_map_[context.type];
1318
+ state.nonce = context.nonce;
1319
+ // If we got an error, set state.status so that we'll NACK the update.
1320
+ if (!context.errors.empty()) {
1321
+ state.status = absl::UnavailableError(
1322
+ absl::StrCat("xDS response validation errors: [",
1323
+ absl::StrJoin(context.errors, "; "), "]"));
1127
1324
  LOG(ERROR) << "[xds_client " << xds_client() << "] xds server "
1128
- << xds_channel()->server_.server_uri()
1129
- << ": error parsing ADS response (" << status
1130
- << ") -- ignoring";
1131
- } else {
1132
- seen_response_ = true;
1133
- xds_channel()->SetHealthyLocked();
1134
- // Update nonce.
1135
- auto& state = state_map_[result.type];
1136
- state.nonce = result.nonce;
1137
- // If we got an error, set state.status so that we'll NACK the update.
1138
- if (!result.errors.empty()) {
1139
- state.status = absl::UnavailableError(
1140
- absl::StrCat("xDS response validation errors: [",
1141
- absl::StrJoin(result.errors, "; "), "]"));
1142
- LOG(ERROR) << "[xds_client " << xds_client() << "] xds server "
1143
- << xds_channel()->server_.server_uri()
1144
- << ": ADS response invalid for resource type "
1145
- << result.type_url << " version " << result.version
1146
- << ", will NACK: nonce=" << state.nonce
1147
- << " status=" << state.status;
1148
- }
1149
- // Delete resources not seen in update if needed.
1150
- if (result.type->AllResourcesRequiredInSotW()) {
1151
- for (auto& a : xds_client()->authority_state_map_) {
1152
- const std::string& authority = a.first;
1153
- AuthorityState& authority_state = a.second;
1154
- // Skip authorities that are not using this xDS channel.
1155
- if (authority_state.xds_channels.back() != xds_channel()) {
1156
- continue;
1157
- }
1158
- auto seen_authority_it = result.resources_seen.find(authority);
1159
- // Find this resource type.
1160
- auto type_it = authority_state.resource_map.find(result.type);
1161
- if (type_it == authority_state.resource_map.end()) continue;
1162
- // Iterate over resource ids.
1163
- for (auto& r : type_it->second) {
1164
- const XdsResourceKey& resource_key = r.first;
1165
- ResourceState& resource_state = r.second;
1166
- if (seen_authority_it == result.resources_seen.end() ||
1167
- seen_authority_it->second.find(resource_key) ==
1168
- seen_authority_it->second.end()) {
1169
- // If the resource was newly requested but has not yet been
1170
- // received, we don't want to generate an error for the
1171
- // watchers, because this ADS response may be in reaction to an
1172
- // earlier request that did not yet request the new resource, so
1173
- // its absence from the response does not necessarily indicate
1174
- // that the resource does not exist. For that case, we rely on
1175
- // the request timeout instead.
1176
- if (resource_state.resource == nullptr) continue;
1177
- if (xds_channel()->server_.IgnoreResourceDeletion()) {
1178
- if (!resource_state.ignored_deletion) {
1179
- LOG(ERROR)
1180
- << "[xds_client " << xds_client() << "] xds server "
1181
- << xds_channel()->server_.server_uri()
1182
- << ": ignoring deletion for resource type "
1183
- << result.type_url << " name "
1184
- << XdsClient::ConstructFullXdsResourceName(
1185
- authority, result.type_url.c_str(), resource_key);
1186
- resource_state.ignored_deletion = true;
1187
- }
1188
- } else {
1189
- resource_state.resource.reset();
1190
- resource_state.meta.client_status =
1191
- XdsApi::ResourceMetadata::DOES_NOT_EXIST;
1192
- xds_client()->NotifyWatchersOnResourceDoesNotExist(
1193
- resource_state.watchers, read_delay_handle);
1194
- }
1195
- }
1325
+ << xds_channel()->server_uri()
1326
+ << ": ADS response invalid for resource type "
1327
+ << context.type_url << " version " << context.version
1328
+ << ", will NACK: nonce=" << state.nonce
1329
+ << " status=" << state.status;
1330
+ }
1331
+ // Delete resources not seen in update if needed.
1332
+ if (context.type->AllResourcesRequiredInSotW()) {
1333
+ for (auto& [authority, authority_state] :
1334
+ xds_client()->authority_state_map_) {
1335
+ // Skip authorities that are not using this xDS channel.
1336
+ if (authority_state.xds_channels.back() != xds_channel()) {
1337
+ continue;
1338
+ }
1339
+ auto seen_authority_it = context.resources_seen.find(authority);
1340
+ // Find this resource type.
1341
+ auto type_it = authority_state.type_map.find(context.type);
1342
+ if (type_it == authority_state.type_map.end()) continue;
1343
+ // Iterate over resource ids.
1344
+ for (auto& [resource_key, resource_state] : type_it->second) {
1345
+ if (seen_authority_it == context.resources_seen.end() ||
1346
+ seen_authority_it->second.find(resource_key) ==
1347
+ seen_authority_it->second.end()) {
1348
+ // If the resource was newly requested but has not yet been
1349
+ // received, we don't want to generate an error for the
1350
+ // watchers, because this ADS response may be in reaction to an
1351
+ // earlier request that did not yet request the new resource, so
1352
+ // its absence from the response does not necessarily indicate
1353
+ // that the resource does not exist. For that case, we rely on
1354
+ // the request timeout instead.
1355
+ if (!resource_state.HasResource()) continue;
1356
+ const bool drop_cached_resource =
1357
+ XdsDataErrorHandlingEnabled()
1358
+ ? xds_channel()->server_.FailOnDataErrors()
1359
+ : !xds_channel()->server_.IgnoreResourceDeletion();
1360
+ resource_state.SetDoesNotExistOnLdsOrCdsDeletion(
1361
+ context.version, context.update_time, drop_cached_resource);
1362
+ xds_client()->NotifyWatchersOnError(resource_state,
1363
+ context.read_delay_handle);
1196
1364
  }
1197
1365
  }
1198
1366
  }
1199
- // If we had valid resources or the update was empty, update the version.
1200
- if (result.num_valid_resources > 0 || result.errors.empty()) {
1201
- xds_channel()->resource_type_version_map_[result.type] =
1202
- std::move(result.version);
1203
- }
1204
- // Send ACK or NACK.
1205
- SendMessageLocked(result.type);
1206
1367
  }
1207
- // Update metrics.
1208
- if (xds_client()->metrics_reporter_ != nullptr) {
1209
- xds_client()->metrics_reporter_->ReportResourceUpdates(
1210
- xds_channel()->server_.server_uri(), result.type_url,
1211
- result.num_valid_resources, result.num_invalid_resources);
1368
+ // If we had valid resources or the update was empty, update the version.
1369
+ if (context.num_valid_resources > 0 || context.errors.empty()) {
1370
+ xds_channel()->resource_type_version_map_[context.type] =
1371
+ std::move(context.version);
1212
1372
  }
1373
+ // Send ACK or NACK.
1374
+ SendMessageLocked(context.type);
1375
+ }
1376
+ // Update metrics.
1377
+ if (xds_client()->metrics_reporter_ != nullptr) {
1378
+ xds_client()->metrics_reporter_->ReportResourceUpdates(
1379
+ xds_channel()->server_uri(), context.type_url,
1380
+ context.num_valid_resources, context.num_invalid_resources);
1213
1381
  }
1214
- xds_client()->work_serializer_.DrainQueue();
1215
1382
  }
1216
1383
 
1217
1384
  void XdsClient::XdsChannel::AdsCall::OnStatusReceived(absl::Status status) {
1218
- {
1219
- MutexLock lock(&xds_client()->mu_);
1220
- GRPC_TRACE_LOG(xds_client, INFO)
1221
- << "[xds_client " << xds_client() << "] xds server "
1222
- << xds_channel()->server_.server_uri()
1223
- << ": ADS call status received (xds_channel=" << xds_channel()
1224
- << ", ads_call=" << this << ", streaming_call=" << streaming_call_.get()
1225
- << "): " << status;
1226
- // Cancel any does-not-exist timers that may be pending.
1227
- for (const auto& p : state_map_) {
1228
- for (const auto& q : p.second.subscribed_resources) {
1229
- for (auto& r : q.second) {
1230
- r.second->MaybeCancelTimer();
1231
- }
1385
+ MutexLock lock(&xds_client()->mu_);
1386
+ GRPC_TRACE_LOG(xds_client, INFO)
1387
+ << "[xds_client " << xds_client() << "] xds server "
1388
+ << xds_channel()->server_uri()
1389
+ << ": ADS call status received (xds_channel=" << xds_channel()
1390
+ << ", ads_call=" << this << ", streaming_call=" << streaming_call_.get()
1391
+ << "): " << status;
1392
+ // Cancel any does-not-exist timers that may be pending.
1393
+ for (const auto& [_, resource_type_state] : state_map_) {
1394
+ for (const auto& [_, resource_map] :
1395
+ resource_type_state.subscribed_resources) {
1396
+ for (auto& [_, resource_timer] : resource_map) {
1397
+ resource_timer->MaybeCancelTimer();
1232
1398
  }
1233
1399
  }
1234
- // Ignore status from a stale call.
1235
- if (IsCurrentCallOnChannel()) {
1236
- // Try to restart the call.
1237
- retryable_call_->OnCallFinishedLocked();
1238
- // If we didn't receive a response on the stream, report the
1239
- // stream failure as a connectivity failure, which will report the
1240
- // error to all watchers of resources on this channel.
1241
- if (!seen_response_) {
1242
- xds_channel()->SetChannelStatusLocked(absl::UnavailableError(
1243
- absl::StrCat("xDS call failed with no responses received; status: ",
1244
- status.ToString())));
1245
- }
1400
+ }
1401
+ // Ignore status from a stale call.
1402
+ if (IsCurrentCallOnChannel()) {
1403
+ // Try to restart the call.
1404
+ retryable_call_->OnCallFinishedLocked();
1405
+ // If we didn't receive a response on the stream, report the
1406
+ // stream failure as a connectivity failure, which will report the
1407
+ // error to all watchers of resources on this channel.
1408
+ if (!seen_response_) {
1409
+ xds_channel()->SetChannelStatusLocked(absl::UnavailableError(
1410
+ absl::StrCat("xDS call failed with no responses received; status: ",
1411
+ status.ToString())));
1246
1412
  }
1247
1413
  }
1248
- xds_client()->work_serializer_.DrainQueue();
1249
1414
  }
1250
1415
 
1251
1416
  bool XdsClient::XdsChannel::AdsCall::IsCurrentCallOnChannel() const {
@@ -1261,13 +1426,10 @@ XdsClient::XdsChannel::AdsCall::ResourceNamesForRequest(
1261
1426
  std::vector<std::string> resource_names;
1262
1427
  auto it = state_map_.find(type);
1263
1428
  if (it != state_map_.end()) {
1264
- for (auto& a : it->second.subscribed_resources) {
1265
- const std::string& authority = a.first;
1266
- for (auto& p : a.second) {
1267
- const XdsResourceKey& resource_key = p.first;
1429
+ for (auto& [authority, authority_state] : it->second.subscribed_resources) {
1430
+ for (auto& [resource_key, resource_timer] : authority_state) {
1268
1431
  resource_names.emplace_back(XdsClient::ConstructFullXdsResourceName(
1269
1432
  authority, type->type_url(), resource_key));
1270
- OrphanablePtr<ResourceTimer>& resource_timer = p.second;
1271
1433
  resource_timer->MarkSubscriptionSendStarted();
1272
1434
  }
1273
1435
  }
@@ -1276,238 +1438,141 @@ XdsClient::XdsChannel::AdsCall::ResourceNamesForRequest(
1276
1438
  }
1277
1439
 
1278
1440
  //
1279
- // XdsClient::XdsChannel::LrsCall::Timer
1441
+ // XdsClient::ResourceState
1280
1442
  //
1281
1443
 
1282
- void XdsClient::XdsChannel::LrsCall::Timer::Orphan() {
1283
- if (timer_handle_.has_value()) {
1284
- xds_client()->engine()->Cancel(*timer_handle_);
1285
- timer_handle_.reset();
1286
- }
1287
- Unref(DEBUG_LOCATION, "Orphan");
1288
- }
1289
-
1290
- void XdsClient::XdsChannel::LrsCall::Timer::ScheduleNextReportLocked() {
1291
- GRPC_TRACE_LOG(xds_client, INFO)
1292
- << "[xds_client " << xds_client() << "] xds server "
1293
- << lrs_call_->xds_channel()->server_.server_uri()
1294
- << ": scheduling next load report in "
1295
- << lrs_call_->load_reporting_interval_;
1296
- timer_handle_ = xds_client()->engine()->RunAfter(
1297
- lrs_call_->load_reporting_interval_,
1298
- [self = Ref(DEBUG_LOCATION, "timer")]() {
1299
- ApplicationCallbackExecCtx callback_exec_ctx;
1300
- ExecCtx exec_ctx;
1301
- self->OnNextReportTimer();
1302
- });
1303
- }
1304
-
1305
- void XdsClient::XdsChannel::LrsCall::Timer::OnNextReportTimer() {
1306
- MutexLock lock(&xds_client()->mu_);
1307
- timer_handle_.reset();
1308
- if (IsCurrentTimerOnCall()) lrs_call_->SendReportLocked();
1309
- }
1310
-
1311
- //
1312
- // XdsClient::XdsChannel::LrsCall
1313
- //
1314
-
1315
- XdsClient::XdsChannel::LrsCall::LrsCall(
1316
- RefCountedPtr<RetryableCall<LrsCall>> retryable_call)
1317
- : InternallyRefCounted<LrsCall>(
1318
- GRPC_TRACE_FLAG_ENABLED(xds_client_refcount) ? "LrsCall" : nullptr),
1319
- retryable_call_(std::move(retryable_call)) {
1320
- // Init the LRS call. Note that the call will progress every time there's
1321
- // activity in xds_client()->interested_parties_, which is comprised of
1322
- // the polling entities from client_channel.
1323
- CHECK_NE(xds_client(), nullptr);
1324
- const char* method =
1325
- "/envoy.service.load_stats.v3.LoadReportingService/StreamLoadStats";
1326
- streaming_call_ = xds_channel()->transport_->CreateStreamingCall(
1327
- method, std::make_unique<StreamEventHandler>(
1328
- // Passing the initial ref here. This ref will go away when
1329
- // the StreamEventHandler is destroyed.
1330
- RefCountedPtr<LrsCall>(this)));
1331
- CHECK(streaming_call_ != nullptr);
1332
- // Start the call.
1333
- GRPC_TRACE_LOG(xds_client, INFO)
1334
- << "[xds_client " << xds_client() << "] xds server "
1335
- << xds_channel()->server_.server_uri()
1336
- << ": starting LRS call (lrs_call=" << this
1337
- << ", streaming_call=" << streaming_call_.get() << ")";
1338
- // Send the initial request.
1339
- std::string serialized_payload = xds_client()->api_.CreateLrsInitialRequest();
1340
- SendMessageLocked(std::move(serialized_payload));
1341
- // Read initial response.
1342
- streaming_call_->StartRecvMessage();
1343
- }
1344
-
1345
- void XdsClient::XdsChannel::LrsCall::Orphan() {
1346
- timer_.reset();
1347
- // Note that the initial ref is held by the StreamEventHandler, which
1348
- // will be destroyed when streaming_call_ is destroyed, which may not happen
1349
- // here, since there may be other refs held to streaming_call_ by internal
1350
- // callbacks.
1351
- streaming_call_.reset();
1352
- }
1353
-
1354
- void XdsClient::XdsChannel::LrsCall::MaybeScheduleNextReportLocked() {
1355
- // If there are no more registered stats to report, cancel the call.
1356
- auto it = xds_client()->xds_load_report_server_map_.find(
1357
- xds_channel()->server_.Key());
1358
- if (it == xds_client()->xds_load_report_server_map_.end() ||
1359
- it->second.load_report_map.empty()) {
1360
- it->second.xds_channel->StopLrsCallLocked();
1361
- return;
1444
+ void XdsClient::ResourceState::SetAcked(
1445
+ std::shared_ptr<const XdsResourceType::ResourceData> resource,
1446
+ std::string serialized_proto, std::string version, Timestamp update_time) {
1447
+ resource_ = std::move(resource);
1448
+ client_status_ = ClientResourceStatus::ACKED;
1449
+ serialized_proto_ = std::move(serialized_proto);
1450
+ update_time_ = update_time;
1451
+ version_ = std::move(version);
1452
+ failed_version_.clear();
1453
+ failed_status_ = absl::OkStatus();
1454
+ }
1455
+
1456
+ void XdsClient::ResourceState::SetNacked(const std::string& version,
1457
+ absl::string_view details,
1458
+ Timestamp update_time,
1459
+ bool drop_cached_resource) {
1460
+ if (drop_cached_resource) {
1461
+ resource_.reset();
1462
+ serialized_proto_.clear();
1463
+ }
1464
+ client_status_ = ClientResourceStatus::NACKED;
1465
+ failed_status_ =
1466
+ absl::InvalidArgumentError(absl::StrCat("invalid resource: ", details));
1467
+ failed_version_ = version;
1468
+ failed_update_time_ = update_time;
1469
+ }
1470
+
1471
+ void XdsClient::ResourceState::SetReceivedError(const std::string& version,
1472
+ absl::Status status,
1473
+ Timestamp update_time,
1474
+ bool drop_cached_resource) {
1475
+ if (drop_cached_resource) {
1476
+ resource_.reset();
1477
+ serialized_proto_.clear();
1478
+ }
1479
+ client_status_ = ClientResourceStatus::RECEIVED_ERROR;
1480
+ failed_version_ = version;
1481
+ failed_status_ = std::move(status);
1482
+ failed_update_time_ = update_time;
1483
+ }
1484
+
1485
+ void XdsClient::ResourceState::SetDoesNotExistOnLdsOrCdsDeletion(
1486
+ const std::string& version, Timestamp update_time,
1487
+ bool drop_cached_resource) {
1488
+ if (drop_cached_resource) {
1489
+ resource_.reset();
1490
+ serialized_proto_.clear();
1491
+ }
1492
+ client_status_ = ClientResourceStatus::DOES_NOT_EXIST;
1493
+ failed_status_ = absl::NotFoundError("does not exist");
1494
+ failed_version_ = version;
1495
+ failed_update_time_ = update_time;
1496
+ }
1497
+
1498
+ void XdsClient::ResourceState::SetDoesNotExistOnTimeout() {
1499
+ client_status_ = ClientResourceStatus::DOES_NOT_EXIST;
1500
+ failed_status_ = absl::NotFoundError("does not exist");
1501
+ failed_version_.clear();
1502
+ }
1503
+
1504
+ void XdsClient::ResourceState::SetTimeout(const std::string& details) {
1505
+ client_status_ = ClientResourceStatus::TIMEOUT;
1506
+ failed_status_ = absl::UnavailableError(details);
1507
+ failed_version_.clear();
1508
+ }
1509
+
1510
+ absl::string_view XdsClient::ResourceState::CacheStateString() const {
1511
+ switch (client_status_) {
1512
+ case ClientResourceStatus::REQUESTED:
1513
+ return "requested";
1514
+ case ClientResourceStatus::DOES_NOT_EXIST:
1515
+ return resource_ != nullptr ? "does_not_exist_but_cached"
1516
+ : "does_not_exist";
1517
+ case ClientResourceStatus::ACKED:
1518
+ return "acked";
1519
+ case ClientResourceStatus::NACKED:
1520
+ return resource_ != nullptr ? "nacked_but_cached" : "nacked";
1521
+ case ClientResourceStatus::RECEIVED_ERROR:
1522
+ return resource_ != nullptr ? "received_error_but_cached"
1523
+ : "received_error";
1524
+ case ClientResourceStatus::TIMEOUT:
1525
+ return "timeout";
1362
1526
  }
1363
- // Don't start if the previous send_message op hasn't completed yet.
1364
- // If this happens, we'll be called again from OnRequestSent().
1365
- if (send_message_pending_) return;
1366
- // Don't start if no LRS response has arrived.
1367
- if (!seen_response()) return;
1368
- // If there is no timer, create one.
1369
- // This happens on the initial response and whenever the interval changes.
1370
- if (timer_ == nullptr) {
1371
- timer_ = MakeOrphanable<Timer>(Ref(DEBUG_LOCATION, "LRS timer"));
1372
- }
1373
- // Schedule the next load report.
1374
- timer_->ScheduleNextReportLocked();
1527
+ Crash("unknown resource state");
1375
1528
  }
1376
1529
 
1377
1530
  namespace {
1378
1531
 
1379
- bool LoadReportCountersAreZero(const XdsApi::ClusterLoadReportMap& snapshot) {
1380
- for (const auto& p : snapshot) {
1381
- const XdsApi::ClusterLoadReport& cluster_snapshot = p.second;
1382
- if (!cluster_snapshot.dropped_requests.IsZero()) return false;
1383
- for (const auto& q : cluster_snapshot.locality_stats) {
1384
- const XdsClusterLocalityStats::Snapshot& locality_snapshot = q.second;
1385
- if (!locality_snapshot.IsZero()) return false;
1386
- }
1387
- }
1388
- return true;
1532
+ google_protobuf_Timestamp* EncodeTimestamp(Timestamp value, upb_Arena* arena) {
1533
+ google_protobuf_Timestamp* timestamp = google_protobuf_Timestamp_new(arena);
1534
+ gpr_timespec timespec = value.as_timespec(GPR_CLOCK_REALTIME);
1535
+ google_protobuf_Timestamp_set_seconds(timestamp, timespec.tv_sec);
1536
+ google_protobuf_Timestamp_set_nanos(timestamp, timespec.tv_nsec);
1537
+ return timestamp;
1389
1538
  }
1390
1539
 
1391
1540
  } // namespace
1392
1541
 
1393
- void XdsClient::XdsChannel::LrsCall::SendReportLocked() {
1394
- // Construct snapshot from all reported stats.
1395
- XdsApi::ClusterLoadReportMap snapshot =
1396
- xds_client()->BuildLoadReportSnapshotLocked(
1397
- xds_channel()->server_, send_all_clusters_, cluster_names_);
1398
- // Skip client load report if the counters were all zero in the last
1399
- // report and they are still zero in this one.
1400
- const bool old_val = last_report_counters_were_zero_;
1401
- last_report_counters_were_zero_ = LoadReportCountersAreZero(snapshot);
1402
- if (old_val && last_report_counters_were_zero_) {
1403
- MaybeScheduleNextReportLocked();
1404
- return;
1405
- }
1406
- // Send a request that contains the snapshot.
1407
- std::string serialized_payload =
1408
- xds_client()->api_.CreateLrsRequest(std::move(snapshot));
1409
- SendMessageLocked(std::move(serialized_payload));
1410
- }
1411
-
1412
- void XdsClient::XdsChannel::LrsCall::SendMessageLocked(std::string payload) {
1413
- send_message_pending_ = true;
1414
- streaming_call_->SendMessage(std::move(payload));
1415
- }
1416
-
1417
- void XdsClient::XdsChannel::LrsCall::OnRequestSent() {
1418
- MutexLock lock(&xds_client()->mu_);
1419
- send_message_pending_ = false;
1420
- if (IsCurrentCallOnChannel()) MaybeScheduleNextReportLocked();
1421
- }
1422
-
1423
- void XdsClient::XdsChannel::LrsCall::OnRecvMessage(absl::string_view payload) {
1424
- MutexLock lock(&xds_client()->mu_);
1425
- // If we're no longer the current call, ignore the result.
1426
- if (!IsCurrentCallOnChannel()) return;
1427
- // Start recv after any code branch
1428
- auto cleanup = absl::MakeCleanup(
1429
- [call = streaming_call_.get()]() { call->StartRecvMessage(); });
1430
- // Parse the response.
1431
- bool send_all_clusters = false;
1432
- std::set<std::string> new_cluster_names;
1433
- Duration new_load_reporting_interval;
1434
- absl::Status status = xds_client()->api_.ParseLrsResponse(
1435
- payload, &send_all_clusters, &new_cluster_names,
1436
- &new_load_reporting_interval);
1437
- if (!status.ok()) {
1438
- LOG(ERROR) << "[xds_client " << xds_client() << "] xds server "
1439
- << xds_channel()->server_.server_uri()
1440
- << ": LRS response parsing failed: " << status;
1441
- return;
1542
+ void XdsClient::ResourceState::FillGenericXdsConfig(
1543
+ upb_StringView type_url, upb_StringView resource_name, upb_Arena* arena,
1544
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig* entry) const {
1545
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_type_url(entry,
1546
+ type_url);
1547
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_name(entry,
1548
+ resource_name);
1549
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_client_status(
1550
+ entry, client_status_);
1551
+ if (!serialized_proto_.empty()) {
1552
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_version_info(
1553
+ entry, StdStringToUpbString(version_));
1554
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_last_updated(
1555
+ entry, EncodeTimestamp(update_time_, arena));
1556
+ auto* any_field =
1557
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_mutable_xds_config(
1558
+ entry, arena);
1559
+ google_protobuf_Any_set_type_url(any_field, type_url);
1560
+ google_protobuf_Any_set_value(any_field,
1561
+ StdStringToUpbString(serialized_proto_));
1442
1562
  }
1443
- seen_response_ = true;
1444
- if (GRPC_TRACE_FLAG_ENABLED(xds_client)) {
1445
- LOG(INFO) << "[xds_client " << xds_client() << "] xds server "
1446
- << xds_channel()->server_.server_uri()
1447
- << ": LRS response received, " << new_cluster_names.size()
1448
- << " cluster names, send_all_clusters=" << send_all_clusters
1449
- << ", load_report_interval="
1450
- << new_load_reporting_interval.millis() << "ms";
1451
- size_t i = 0;
1452
- for (const auto& name : new_cluster_names) {
1453
- LOG(INFO) << "[xds_client " << xds_client() << "] cluster_name " << i++
1454
- << ": " << name;
1563
+ if (!failed_status_.ok()) {
1564
+ auto* update_failure_state = envoy_admin_v3_UpdateFailureState_new(arena);
1565
+ envoy_admin_v3_UpdateFailureState_set_details(
1566
+ update_failure_state, StdStringToUpbString(failed_status_.message()));
1567
+ if (!failed_version_.empty()) {
1568
+ envoy_admin_v3_UpdateFailureState_set_version_info(
1569
+ update_failure_state, StdStringToUpbString(failed_version_));
1570
+ envoy_admin_v3_UpdateFailureState_set_last_update_attempt(
1571
+ update_failure_state, EncodeTimestamp(failed_update_time_, arena));
1455
1572
  }
1573
+ envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_error_state(
1574
+ entry, update_failure_state);
1456
1575
  }
1457
- if (new_load_reporting_interval <
1458
- Duration::Milliseconds(GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS)) {
1459
- new_load_reporting_interval =
1460
- Duration::Milliseconds(GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS);
1461
- GRPC_TRACE_LOG(xds_client, INFO)
1462
- << "[xds_client " << xds_client() << "] xds server "
1463
- << xds_channel()->server_.server_uri()
1464
- << ": increased load_report_interval to minimum value "
1465
- << GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS << "ms";
1466
- }
1467
- // Ignore identical update.
1468
- if (send_all_clusters == send_all_clusters_ &&
1469
- cluster_names_ == new_cluster_names &&
1470
- load_reporting_interval_ == new_load_reporting_interval) {
1471
- GRPC_TRACE_LOG(xds_client, INFO)
1472
- << "[xds_client " << xds_client() << "] xds server "
1473
- << xds_channel()->server_.server_uri()
1474
- << ": incoming LRS response identical to current, ignoring.";
1475
- return;
1476
- }
1477
- // If the interval has changed, we'll need to restart the timer below.
1478
- const bool restart_timer =
1479
- load_reporting_interval_ != new_load_reporting_interval;
1480
- // Record the new config.
1481
- send_all_clusters_ = send_all_clusters;
1482
- cluster_names_ = std::move(new_cluster_names);
1483
- load_reporting_interval_ = new_load_reporting_interval;
1484
- // Restart timer if needed.
1485
- if (restart_timer) {
1486
- timer_.reset();
1487
- MaybeScheduleNextReportLocked();
1488
- }
1489
- }
1490
-
1491
- void XdsClient::XdsChannel::LrsCall::OnStatusReceived(absl::Status status) {
1492
- MutexLock lock(&xds_client()->mu_);
1493
- GRPC_TRACE_LOG(xds_client, INFO)
1494
- << "[xds_client " << xds_client() << "] xds server "
1495
- << xds_channel()->server_.server_uri()
1496
- << ": LRS call status received (xds_channel=" << xds_channel()
1497
- << ", lrs_call=" << this << ", streaming_call=" << streaming_call_.get()
1498
- << "): " << status;
1499
- // Ignore status from a stale call.
1500
- if (IsCurrentCallOnChannel()) {
1501
- // Try to restart the call.
1502
- retryable_call_->OnCallFinishedLocked();
1503
- }
1504
- }
1505
-
1506
- bool XdsClient::XdsChannel::LrsCall::IsCurrentCallOnChannel() const {
1507
- // If the retryable LRS call is null (which only happens when the xds
1508
- // channel is shutting down), all the LRS calls are stale.
1509
- if (xds_channel()->lrs_call_ == nullptr) return false;
1510
- return this == xds_channel()->lrs_call_->call();
1511
1576
  }
1512
1577
 
1513
1578
  //
@@ -1517,8 +1582,8 @@ bool XdsClient::XdsChannel::LrsCall::IsCurrentCallOnChannel() const {
1517
1582
  constexpr absl::string_view XdsClient::kOldStyleAuthority;
1518
1583
 
1519
1584
  XdsClient::XdsClient(
1520
- std::unique_ptr<XdsBootstrap> bootstrap,
1521
- OrphanablePtr<XdsTransportFactory> transport_factory,
1585
+ std::shared_ptr<XdsBootstrap> bootstrap,
1586
+ RefCountedPtr<XdsTransportFactory> transport_factory,
1522
1587
  std::shared_ptr<grpc_event_engine::experimental::EventEngine> engine,
1523
1588
  std::unique_ptr<XdsMetricsReporter> metrics_reporter,
1524
1589
  std::string user_agent_name, std::string user_agent_version,
@@ -1526,11 +1591,11 @@ XdsClient::XdsClient(
1526
1591
  : DualRefCounted<XdsClient>(
1527
1592
  GRPC_TRACE_FLAG_ENABLED(xds_client_refcount) ? "XdsClient" : nullptr),
1528
1593
  bootstrap_(std::move(bootstrap)),
1594
+ user_agent_name_(std::move(user_agent_name)),
1595
+ user_agent_version_(std::move(user_agent_version)),
1529
1596
  transport_factory_(std::move(transport_factory)),
1530
1597
  request_timeout_(resource_request_timeout),
1531
1598
  xds_federation_enabled_(XdsFederationEnabled()),
1532
- api_(this, &xds_client_trace, bootstrap_->node(), &def_pool_,
1533
- std::move(user_agent_name), std::move(user_agent_version)),
1534
1599
  work_serializer_(engine),
1535
1600
  engine_(std::move(engine)),
1536
1601
  metrics_reporter_(std::move(metrics_reporter)) {
@@ -1555,15 +1620,13 @@ void XdsClient::Orphaned() {
1555
1620
  MutexLock lock(&mu_);
1556
1621
  shutting_down_ = true;
1557
1622
  // Clear cache and any remaining watchers that may not have been cancelled.
1558
- authority_state_map_.clear();
1623
+ // Note: We move authority_state_map_ out of the way before clearing
1624
+ // it, because clearing the map will trigger calls to
1625
+ // MaybeRemoveUnsubscribedCacheEntriesForTypeLocked(), which would try to
1626
+ // modify the map while we are iterating over it.
1627
+ auto authority_state_map = std::move(authority_state_map_);
1628
+ authority_state_map.clear();
1559
1629
  invalid_watchers_.clear();
1560
- // We may still be sending lingering queued load report data, so don't
1561
- // just clear the load reporting map, but we do want to clear the refs
1562
- // we're holding to the XdsChannel objects, to make sure that
1563
- // everything shuts down properly.
1564
- for (auto& p : xds_load_report_server_map_) {
1565
- p.second.xds_channel.reset(DEBUG_LOCATION, "XdsClient::Orphan()");
1566
- }
1567
1630
  }
1568
1631
 
1569
1632
  RefCountedPtr<XdsClient::XdsChannel> XdsClient::GetOrCreateXdsChannelLocked(
@@ -1581,10 +1644,11 @@ RefCountedPtr<XdsClient::XdsChannel> XdsClient::GetOrCreateXdsChannelLocked(
1581
1644
  }
1582
1645
 
1583
1646
  bool XdsClient::HasUncachedResources(const AuthorityState& authority_state) {
1584
- for (const auto& type_resource : authority_state.resource_map) {
1585
- for (const auto& key_state : type_resource.second) {
1586
- if (key_state.second.meta.client_status ==
1587
- XdsApi::ResourceMetadata::REQUESTED) {
1647
+ for (const auto& [_, resource_map] : authority_state.type_map) {
1648
+ for (const auto& [_, resource_state] : resource_map) {
1649
+ if (resource_state.HasWatchers() &&
1650
+ resource_state.client_status() ==
1651
+ ResourceState::ClientResourceStatus::REQUESTED) {
1588
1652
  return true;
1589
1653
  }
1590
1654
  }
@@ -1595,24 +1659,19 @@ bool XdsClient::HasUncachedResources(const AuthorityState& authority_state) {
1595
1659
  void XdsClient::WatchResource(const XdsResourceType* type,
1596
1660
  absl::string_view name,
1597
1661
  RefCountedPtr<ResourceWatcherInterface> watcher) {
1598
- ResourceWatcherInterface* w = watcher.get();
1599
1662
  // Lambda for handling failure cases.
1600
1663
  auto fail = [&](absl::Status status) mutable {
1601
1664
  {
1602
1665
  MutexLock lock(&mu_);
1603
1666
  MaybeRegisterResourceTypeLocked(type);
1604
- invalid_watchers_[w] = watcher;
1667
+ invalid_watchers_.insert(watcher);
1605
1668
  }
1606
- work_serializer_.Run(
1607
- [watcher = std::move(watcher), status = std::move(status)]()
1608
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) {
1609
- watcher->OnError(status, ReadDelayHandle::NoWait());
1610
- },
1611
- DEBUG_LOCATION);
1669
+ NotifyWatchersOnResourceChanged(std::move(status), {watcher},
1670
+ ReadDelayHandle::NoWait());
1612
1671
  };
1613
1672
  auto resource_name = ParseXdsResourceName(name, type);
1614
1673
  if (!resource_name.ok()) {
1615
- fail(absl::UnavailableError(
1674
+ fail(absl::InvalidArgumentError(
1616
1675
  absl::StrCat("Unable to parse resource name ", name)));
1617
1676
  return;
1618
1677
  }
@@ -1622,7 +1681,7 @@ void XdsClient::WatchResource(const XdsResourceType* type,
1622
1681
  auto* authority =
1623
1682
  bootstrap_->LookupAuthority(std::string(resource_name->authority));
1624
1683
  if (authority == nullptr) {
1625
- fail(absl::UnavailableError(
1684
+ fail(absl::FailedPreconditionError(
1626
1685
  absl::StrCat("authority \"", resource_name->authority,
1627
1686
  "\" not present in bootstrap config")));
1628
1687
  return;
@@ -1630,103 +1689,67 @@ void XdsClient::WatchResource(const XdsResourceType* type,
1630
1689
  xds_servers = authority->servers();
1631
1690
  }
1632
1691
  if (xds_servers.empty()) xds_servers = bootstrap_->servers();
1633
- {
1634
- MutexLock lock(&mu_);
1635
- MaybeRegisterResourceTypeLocked(type);
1636
-
1637
- AuthorityState& authority_state =
1638
- authority_state_map_[resource_name->authority];
1639
- auto it_is_new = authority_state.resource_map[type].emplace(
1640
- resource_name->key, ResourceState());
1641
- bool first_watcher_for_resource = it_is_new.second;
1642
- ResourceState& resource_state = it_is_new.first->second;
1643
- resource_state.watchers[w] = watcher;
1644
- if (first_watcher_for_resource) {
1645
- // We try to add new channels in 2 cases:
1646
- // - This is the first resource for this authority (i.e., the list
1647
- // of channels is empty).
1648
- // - The last channel in the list is failing. That failure may not
1649
- // have previously triggered fallback if there were no uncached
1650
- // resources, but we've just added a new uncached resource,
1651
- // so we need to trigger fallback now.
1652
- //
1653
- // Note that when we add a channel, it might already be failing
1654
- // due to being used in a different authority. So we keep going
1655
- // until either we add one that isn't failing or we've added them all.
1656
- if (authority_state.xds_channels.empty() ||
1657
- !authority_state.xds_channels.back()->status().ok()) {
1658
- for (size_t i = authority_state.xds_channels.size();
1659
- i < xds_servers.size(); ++i) {
1660
- authority_state.xds_channels.emplace_back(
1661
- GetOrCreateXdsChannelLocked(*xds_servers[i], "start watch"));
1662
- if (authority_state.xds_channels.back()->status().ok()) {
1663
- break;
1664
- }
1665
- }
1666
- }
1667
- for (const auto& channel : authority_state.xds_channels) {
1668
- channel->SubscribeLocked(type, *resource_name);
1669
- }
1670
- } else {
1671
- // If we already have a cached value for the resource, notify the new
1672
- // watcher immediately.
1673
- if (resource_state.resource != nullptr) {
1674
- GRPC_TRACE_LOG(xds_client, INFO)
1675
- << "[xds_client " << this << "] returning cached listener data for "
1676
- << name;
1677
- work_serializer_.Schedule(
1678
- [watcher, value = resource_state.resource]()
1679
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) {
1680
- watcher->OnGenericResourceChanged(value,
1681
- ReadDelayHandle::NoWait());
1682
- },
1683
- DEBUG_LOCATION);
1684
- } else if (resource_state.meta.client_status ==
1685
- XdsApi::ResourceMetadata::DOES_NOT_EXIST) {
1686
- GRPC_TRACE_LOG(xds_client, INFO)
1687
- << "[xds_client " << this
1688
- << "] reporting cached does-not-exist for " << name;
1689
- work_serializer_.Schedule(
1690
- [watcher]() ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) {
1691
- watcher->OnResourceDoesNotExist(ReadDelayHandle::NoWait());
1692
- },
1693
- DEBUG_LOCATION);
1694
- } else if (resource_state.meta.client_status ==
1695
- XdsApi::ResourceMetadata::NACKED) {
1696
- GRPC_TRACE_LOG(xds_client, INFO)
1697
- << "[xds_client " << this
1698
- << "] reporting cached validation failure for " << name << ": "
1699
- << resource_state.meta.failed_details;
1700
- std::string details = resource_state.meta.failed_details;
1701
- const auto* node = bootstrap_->node();
1702
- if (node != nullptr) {
1703
- absl::StrAppend(&details, " (node ID:", bootstrap_->node()->id(),
1704
- ")");
1692
+ MutexLock lock(&mu_);
1693
+ MaybeRegisterResourceTypeLocked(type);
1694
+ AuthorityState& authority_state =
1695
+ authority_state_map_[resource_name->authority];
1696
+ auto [it, created_entry] = authority_state.type_map[type].emplace(
1697
+ resource_name->key, ResourceState());
1698
+ ResourceState& resource_state = it->second;
1699
+ resource_state.AddWatcher(watcher);
1700
+ if (created_entry) {
1701
+ // We try to add new channels in 2 cases:
1702
+ // - This is the first resource for this authority (i.e., the list
1703
+ // of channels is empty).
1704
+ // - The last channel in the list is failing. That failure may not
1705
+ // have previously triggered fallback if there were no uncached
1706
+ // resources, but we've just added a new uncached resource,
1707
+ // so we need to trigger fallback now.
1708
+ //
1709
+ // Note that when we add a channel, it might already be failing
1710
+ // due to being used in a different authority. So we keep going
1711
+ // until either we add one that isn't failing or we've added them all.
1712
+ if (authority_state.xds_channels.empty() ||
1713
+ !authority_state.xds_channels.back()->status().ok()) {
1714
+ for (size_t i = authority_state.xds_channels.size();
1715
+ i < xds_servers.size(); ++i) {
1716
+ authority_state.xds_channels.emplace_back(
1717
+ GetOrCreateXdsChannelLocked(*xds_servers[i], "start watch"));
1718
+ if (authority_state.xds_channels.back()->status().ok()) {
1719
+ break;
1705
1720
  }
1706
- work_serializer_.Schedule(
1707
- [watcher, details = std::move(details)]()
1708
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) {
1709
- watcher->OnError(absl::UnavailableError(absl::StrCat(
1710
- "invalid resource: ", details)),
1711
- ReadDelayHandle::NoWait());
1712
- },
1713
- DEBUG_LOCATION);
1714
1721
  }
1715
1722
  }
1716
- absl::Status channel_status = authority_state.xds_channels.back()->status();
1717
- if (!channel_status.ok()) {
1723
+ } else {
1724
+ // If we already have a cached value for the resource, notify the new
1725
+ // watcher immediately.
1726
+ if (resource_state.HasResource()) {
1718
1727
  GRPC_TRACE_LOG(xds_client, INFO)
1719
- << "[xds_client " << this << "] returning cached channel error for "
1720
- << name << ": " << channel_status;
1721
- work_serializer_.Schedule(
1722
- [watcher = std::move(watcher), status = std::move(channel_status)]()
1723
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) mutable {
1724
- watcher->OnError(std::move(status), ReadDelayHandle::NoWait());
1725
- },
1726
- DEBUG_LOCATION);
1728
+ << "[xds_client " << this << "] returning cached data for " << name;
1729
+ NotifyWatchersOnResourceChanged(resource_state.resource(), {watcher},
1730
+ ReadDelayHandle::NoWait());
1727
1731
  }
1732
+ if (!resource_state.failed_status().ok()) {
1733
+ GRPC_TRACE_LOG(xds_client, INFO)
1734
+ << "[xds_client " << this << "] returning cached error for " << name
1735
+ << ": " << resource_state.failed_status();
1736
+ NotifyWatchersOnError(resource_state, ReadDelayHandle::NoWait(),
1737
+ {watcher});
1738
+ }
1739
+ }
1740
+ // Make sure all channels are subscribing to the resource.
1741
+ for (const auto& channel : authority_state.xds_channels) {
1742
+ channel->SubscribeLocked(type, *resource_name);
1743
+ }
1744
+ // If the channel is not connected, report an error to the watcher.
1745
+ absl::Status channel_status = authority_state.xds_channels.back()->status();
1746
+ if (!channel_status.ok()) {
1747
+ GRPC_TRACE_LOG(xds_client, INFO)
1748
+ << "[xds_client " << this << "] returning cached channel error for "
1749
+ << name << ": " << channel_status;
1750
+ NotifyWatchersOnError(resource_state, ReadDelayHandle::NoWait(), {watcher},
1751
+ std::move(channel_status));
1728
1752
  }
1729
- work_serializer_.DrainQueue();
1730
1753
  }
1731
1754
 
1732
1755
  void XdsClient::CancelResourceWatch(const XdsResourceType* type,
@@ -1744,34 +1767,63 @@ void XdsClient::CancelResourceWatch(const XdsResourceType* type,
1744
1767
  if (authority_it == authority_state_map_.end()) return;
1745
1768
  AuthorityState& authority_state = authority_it->second;
1746
1769
  // Find type map.
1747
- auto type_it = authority_state.resource_map.find(type);
1748
- if (type_it == authority_state.resource_map.end()) return;
1749
- auto& type_map = type_it->second;
1770
+ auto type_it = authority_state.type_map.find(type);
1771
+ if (type_it == authority_state.type_map.end()) return;
1772
+ auto& resource_map = type_it->second;
1750
1773
  // Find resource key.
1751
- auto resource_it = type_map.find(resource_name->key);
1752
- if (resource_it == type_map.end()) return;
1774
+ auto resource_it = resource_map.find(resource_name->key);
1775
+ if (resource_it == resource_map.end()) return;
1753
1776
  ResourceState& resource_state = resource_it->second;
1754
1777
  // Remove watcher.
1755
- resource_state.watchers.erase(watcher);
1756
- // Clean up empty map entries, if any.
1757
- if (resource_state.watchers.empty()) {
1758
- if (resource_state.ignored_deletion) {
1759
- LOG(INFO) << "[xds_client " << this
1760
- << "] unsubscribing from a resource for which we "
1761
- << "previously ignored a deletion: type " << type->type_url()
1762
- << " name " << name;
1763
- }
1778
+ resource_state.RemoveWatcher(watcher);
1779
+ // If this was the last watcher, clean up.
1780
+ if (!resource_state.HasWatchers()) {
1781
+ // Unsubscribe from this resource on all XdsChannels.
1764
1782
  for (const auto& xds_channel : authority_state.xds_channels) {
1765
1783
  xds_channel->UnsubscribeLocked(type, *resource_name,
1766
1784
  delay_unsubscription);
1767
1785
  }
1768
- type_map.erase(resource_it);
1769
- if (type_map.empty()) {
1770
- authority_state.resource_map.erase(type_it);
1771
- if (authority_state.resource_map.empty()) {
1772
- authority_state.xds_channels.clear();
1786
+ // Note: We wait to remove the cache entry until we actualle send
1787
+ // the unsubscription message on the ADS stream, so that if a watch is
1788
+ // stopped and then started again before we send the next request
1789
+ // for that resource type, we don't lose the cache entry without the
1790
+ // xDS server knowing it needs to re-send it.
1791
+ //
1792
+ // Note: Because the cache cleanup may have been triggered by the
1793
+ // unsubscription, it's no longer safe to access any of the
1794
+ // iterators that we have from above.
1795
+ }
1796
+ }
1797
+
1798
+ void XdsClient::MaybeRemoveUnsubscribedCacheEntriesForTypeLocked(
1799
+ XdsChannel* xds_channel, const XdsResourceType* type) {
1800
+ for (auto authority_it = authority_state_map_.begin();
1801
+ authority_it != authority_state_map_.end();) {
1802
+ AuthorityState& authority_state = authority_it->second;
1803
+ if (authority_state.xds_channels.back() == xds_channel) {
1804
+ // Find type map.
1805
+ auto type_it = authority_state.type_map.find(type);
1806
+ if (type_it != authority_state.type_map.end()) {
1807
+ auto& resource_map = type_it->second;
1808
+ // Remove the cache entry for any resource without watchers.
1809
+ for (auto resource_it = resource_map.begin();
1810
+ resource_it != resource_map.end();) {
1811
+ ResourceState& resource_state = resource_it->second;
1812
+ if (!resource_state.HasWatchers()) {
1813
+ resource_map.erase(resource_it++);
1814
+ } else {
1815
+ ++resource_it;
1816
+ }
1817
+ }
1818
+ // Clean up empty entries in the map.
1819
+ if (resource_map.empty()) authority_state.type_map.erase(type_it);
1773
1820
  }
1774
1821
  }
1822
+ if (authority_state.type_map.empty()) {
1823
+ authority_state_map_.erase(authority_it++);
1824
+ } else {
1825
+ ++authority_it;
1826
+ }
1775
1827
  }
1776
1828
  }
1777
1829
 
@@ -1814,9 +1866,9 @@ absl::StatusOr<XdsClient::XdsResourceName> XdsClient::ParseXdsResourceName(
1814
1866
  }
1815
1867
  // Canonicalize order of query params.
1816
1868
  std::vector<URI::QueryParam> query_params;
1817
- for (const auto& p : uri->query_parameter_map()) {
1869
+ for (const auto& [key, value] : uri->query_parameter_map()) {
1818
1870
  query_params.emplace_back(
1819
- URI::QueryParam{std::string(p.first), std::string(p.second)});
1871
+ URI::QueryParam{std::string(key), std::string(value)});
1820
1872
  }
1821
1873
  return XdsResourceName{
1822
1874
  uri->authority(),
@@ -1837,310 +1889,67 @@ std::string XdsClient::ConstructFullXdsResourceName(
1837
1889
  return key.id;
1838
1890
  }
1839
1891
 
1840
- RefCountedPtr<XdsClusterDropStats> XdsClient::AddClusterDropStats(
1841
- const XdsBootstrap::XdsServer& xds_server, absl::string_view cluster_name,
1842
- absl::string_view eds_service_name) {
1843
- auto key =
1844
- std::make_pair(std::string(cluster_name), std::string(eds_service_name));
1845
- RefCountedPtr<XdsClusterDropStats> cluster_drop_stats;
1846
- {
1847
- MutexLock lock(&mu_);
1848
- // We jump through some hoops here to make sure that the
1849
- // absl::string_views stored in the XdsClusterDropStats object point
1850
- // to the strings in the xds_load_report_server_map_ keys, so that
1851
- // they have the same lifetime.
1852
- auto server_it = xds_load_report_server_map_
1853
- .emplace(xds_server.Key(), LoadReportServer())
1854
- .first;
1855
- if (server_it->second.xds_channel == nullptr) {
1856
- server_it->second.xds_channel = GetOrCreateXdsChannelLocked(
1857
- xds_server, "load report map (drop stats)");
1858
- }
1859
- auto load_report_it = server_it->second.load_report_map
1860
- .emplace(std::move(key), LoadReportState())
1861
- .first;
1862
- LoadReportState& load_report_state = load_report_it->second;
1863
- if (load_report_state.drop_stats != nullptr) {
1864
- cluster_drop_stats = load_report_state.drop_stats->RefIfNonZero();
1865
- }
1866
- if (cluster_drop_stats == nullptr) {
1867
- if (load_report_state.drop_stats != nullptr) {
1868
- load_report_state.deleted_drop_stats +=
1869
- load_report_state.drop_stats->GetSnapshotAndReset();
1870
- }
1871
- cluster_drop_stats = MakeRefCounted<XdsClusterDropStats>(
1872
- Ref(DEBUG_LOCATION, "DropStats"), server_it->first /*xds_server*/,
1873
- load_report_it->first.first /*cluster_name*/,
1874
- load_report_it->first.second /*eds_service_name*/);
1875
- load_report_state.drop_stats = cluster_drop_stats.get();
1876
- }
1877
- server_it->second.xds_channel->MaybeStartLrsCall();
1878
- }
1879
- work_serializer_.DrainQueue();
1880
- return cluster_drop_stats;
1881
- }
1882
-
1883
- void XdsClient::RemoveClusterDropStats(
1884
- absl::string_view xds_server_key, absl::string_view cluster_name,
1885
- absl::string_view eds_service_name,
1886
- XdsClusterDropStats* cluster_drop_stats) {
1887
- MutexLock lock(&mu_);
1888
- auto server_it = xds_load_report_server_map_.find(xds_server_key);
1889
- if (server_it == xds_load_report_server_map_.end()) return;
1890
- auto load_report_it = server_it->second.load_report_map.find(
1891
- std::make_pair(std::string(cluster_name), std::string(eds_service_name)));
1892
- if (load_report_it == server_it->second.load_report_map.end()) return;
1893
- LoadReportState& load_report_state = load_report_it->second;
1894
- if (load_report_state.drop_stats == cluster_drop_stats) {
1895
- // Record final snapshot in deleted_drop_stats, which will be
1896
- // added to the next load report.
1897
- load_report_state.deleted_drop_stats +=
1898
- load_report_state.drop_stats->GetSnapshotAndReset();
1899
- load_report_state.drop_stats = nullptr;
1900
- }
1901
- }
1902
-
1903
- RefCountedPtr<XdsClusterLocalityStats> XdsClient::AddClusterLocalityStats(
1904
- const XdsBootstrap::XdsServer& xds_server, absl::string_view cluster_name,
1905
- absl::string_view eds_service_name,
1906
- RefCountedPtr<XdsLocalityName> locality) {
1907
- auto key =
1908
- std::make_pair(std::string(cluster_name), std::string(eds_service_name));
1909
- RefCountedPtr<XdsClusterLocalityStats> cluster_locality_stats;
1910
- {
1911
- MutexLock lock(&mu_);
1912
- // We jump through some hoops here to make sure that the
1913
- // absl::string_views stored in the XdsClusterDropStats object point
1914
- // to the strings in the xds_load_report_server_map_ keys, so that
1915
- // they have the same lifetime.
1916
- auto server_it = xds_load_report_server_map_
1917
- .emplace(xds_server.Key(), LoadReportServer())
1918
- .first;
1919
- if (server_it->second.xds_channel == nullptr) {
1920
- server_it->second.xds_channel = GetOrCreateXdsChannelLocked(
1921
- xds_server, "load report map (locality stats)");
1922
- }
1923
- auto load_report_it = server_it->second.load_report_map
1924
- .emplace(std::move(key), LoadReportState())
1925
- .first;
1926
- LoadReportState& load_report_state = load_report_it->second;
1927
- LoadReportState::LocalityState& locality_state =
1928
- load_report_state.locality_stats[locality];
1929
- if (locality_state.locality_stats != nullptr) {
1930
- cluster_locality_stats = locality_state.locality_stats->RefIfNonZero();
1931
- }
1932
- if (cluster_locality_stats == nullptr) {
1933
- if (locality_state.locality_stats != nullptr) {
1934
- locality_state.deleted_locality_stats +=
1935
- locality_state.locality_stats->GetSnapshotAndReset();
1936
- }
1937
- cluster_locality_stats = MakeRefCounted<XdsClusterLocalityStats>(
1938
- Ref(DEBUG_LOCATION, "LocalityStats"), server_it->first /*xds_server*/,
1939
- load_report_it->first.first /*cluster_name*/,
1940
- load_report_it->first.second /*eds_service_name*/,
1941
- std::move(locality));
1942
- locality_state.locality_stats = cluster_locality_stats.get();
1943
- }
1944
- server_it->second.xds_channel->MaybeStartLrsCall();
1945
- }
1946
- work_serializer_.DrainQueue();
1947
- return cluster_locality_stats;
1948
- }
1949
-
1950
- void XdsClient::RemoveClusterLocalityStats(
1951
- absl::string_view xds_server_key, absl::string_view cluster_name,
1952
- absl::string_view eds_service_name,
1953
- const RefCountedPtr<XdsLocalityName>& locality,
1954
- XdsClusterLocalityStats* cluster_locality_stats) {
1955
- MutexLock lock(&mu_);
1956
- auto server_it = xds_load_report_server_map_.find(xds_server_key);
1957
- if (server_it == xds_load_report_server_map_.end()) return;
1958
- auto load_report_it = server_it->second.load_report_map.find(
1959
- std::make_pair(std::string(cluster_name), std::string(eds_service_name)));
1960
- if (load_report_it == server_it->second.load_report_map.end()) return;
1961
- LoadReportState& load_report_state = load_report_it->second;
1962
- auto locality_it = load_report_state.locality_stats.find(locality);
1963
- if (locality_it == load_report_state.locality_stats.end()) return;
1964
- LoadReportState::LocalityState& locality_state = locality_it->second;
1965
- if (locality_state.locality_stats == cluster_locality_stats) {
1966
- // Record final snapshot in deleted_locality_stats, which will be
1967
- // added to the next load report.
1968
- locality_state.deleted_locality_stats +=
1969
- locality_state.locality_stats->GetSnapshotAndReset();
1970
- locality_state.locality_stats = nullptr;
1971
- }
1972
- }
1973
-
1974
1892
  void XdsClient::ResetBackoff() {
1975
1893
  MutexLock lock(&mu_);
1976
- for (auto& p : xds_channel_map_) {
1977
- p.second->ResetBackoff();
1894
+ for (auto& [_, xds_channel] : xds_channel_map_) {
1895
+ xds_channel->ResetBackoff();
1978
1896
  }
1979
1897
  }
1980
1898
 
1981
- void XdsClient::NotifyWatchersOnErrorLocked(
1982
- const std::map<ResourceWatcherInterface*,
1983
- RefCountedPtr<ResourceWatcherInterface>>& watchers,
1984
- absl::Status status, RefCountedPtr<ReadDelayHandle> read_delay_handle) {
1899
+ absl::Status XdsClient::AppendNodeToStatus(const absl::Status& status) const {
1985
1900
  const auto* node = bootstrap_->node();
1986
- if (node != nullptr) {
1987
- status = absl::Status(
1988
- status.code(),
1989
- absl::StrCat(status.message(), " (node ID:", node->id(), ")"));
1990
- }
1991
- work_serializer_.Schedule(
1992
- [watchers, status = std::move(status),
1901
+ if (node == nullptr) return status;
1902
+ return absl::Status(
1903
+ status.code(), absl::StrCat(status.message(),
1904
+ " (node ID:", bootstrap_->node()->id(), ")"));
1905
+ }
1906
+
1907
+ void XdsClient::NotifyWatchersOnResourceChanged(
1908
+ absl::StatusOr<std::shared_ptr<const XdsResourceType::ResourceData>>
1909
+ resource,
1910
+ WatcherSet watchers, RefCountedPtr<ReadDelayHandle> read_delay_handle) {
1911
+ if (!resource.ok()) resource = AppendNodeToStatus(resource.status());
1912
+ work_serializer_.Run(
1913
+ [watchers = std::move(watchers), resource = std::move(resource),
1993
1914
  read_delay_handle = std::move(read_delay_handle)]()
1994
1915
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) {
1995
- for (const auto& p : watchers) {
1996
- p.first->OnError(status, read_delay_handle);
1916
+ for (const auto& watcher : watchers) {
1917
+ watcher->OnGenericResourceChanged(resource, read_delay_handle);
1997
1918
  }
1998
1919
  },
1999
1920
  DEBUG_LOCATION);
2000
1921
  }
2001
1922
 
2002
- void XdsClient::NotifyWatchersOnResourceDoesNotExist(
2003
- const std::map<ResourceWatcherInterface*,
2004
- RefCountedPtr<ResourceWatcherInterface>>& watchers,
1923
+ void XdsClient::NotifyWatchersOnAmbientError(
1924
+ absl::Status status, WatcherSet watchers,
2005
1925
  RefCountedPtr<ReadDelayHandle> read_delay_handle) {
2006
- work_serializer_.Schedule(
2007
- [watchers, read_delay_handle = std::move(read_delay_handle)]()
1926
+ if (!status.ok()) status = AppendNodeToStatus(status);
1927
+ work_serializer_.Run(
1928
+ [watchers = std::move(watchers), status = std::move(status),
1929
+ read_delay_handle = std::move(read_delay_handle)]()
2008
1930
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&work_serializer_) {
2009
- for (const auto& p : watchers) {
2010
- p.first->OnResourceDoesNotExist(read_delay_handle);
1931
+ for (const auto& watcher : watchers) {
1932
+ watcher->OnAmbientError(status, read_delay_handle);
2011
1933
  }
2012
1934
  },
2013
1935
  DEBUG_LOCATION);
2014
1936
  }
2015
1937
 
2016
- XdsApi::ClusterLoadReportMap XdsClient::BuildLoadReportSnapshotLocked(
2017
- const XdsBootstrap::XdsServer& xds_server, bool send_all_clusters,
2018
- const std::set<std::string>& clusters) {
2019
- GRPC_TRACE_LOG(xds_client, INFO)
2020
- << "[xds_client " << this << "] start building load report";
2021
- XdsApi::ClusterLoadReportMap snapshot_map;
2022
- auto server_it = xds_load_report_server_map_.find(xds_server.Key());
2023
- if (server_it == xds_load_report_server_map_.end()) return snapshot_map;
2024
- auto& load_report_map = server_it->second.load_report_map;
2025
- for (auto load_report_it = load_report_map.begin();
2026
- load_report_it != load_report_map.end();) {
2027
- // Cluster key is cluster and EDS service name.
2028
- const auto& cluster_key = load_report_it->first;
2029
- LoadReportState& load_report = load_report_it->second;
2030
- // If the CDS response for a cluster indicates to use LRS but the
2031
- // LRS server does not say that it wants reports for this cluster,
2032
- // then we'll have stats objects here whose data we're not going to
2033
- // include in the load report. However, we still need to clear out
2034
- // the data from the stats objects, so that if the LRS server starts
2035
- // asking for the data in the future, we don't incorrectly include
2036
- // data from previous reporting intervals in that future report.
2037
- const bool record_stats =
2038
- send_all_clusters || clusters.find(cluster_key.first) != clusters.end();
2039
- XdsApi::ClusterLoadReport snapshot;
2040
- // Aggregate drop stats.
2041
- snapshot.dropped_requests = std::move(load_report.deleted_drop_stats);
2042
- if (load_report.drop_stats != nullptr) {
2043
- snapshot.dropped_requests +=
2044
- load_report.drop_stats->GetSnapshotAndReset();
2045
- GRPC_TRACE_LOG(xds_client, INFO)
2046
- << "[xds_client " << this << "] cluster=" << cluster_key.first
2047
- << " eds_service_name=" << cluster_key.second
2048
- << " drop_stats=" << load_report.drop_stats;
2049
- }
2050
- // Aggregate locality stats.
2051
- for (auto it = load_report.locality_stats.begin();
2052
- it != load_report.locality_stats.end();) {
2053
- const RefCountedPtr<XdsLocalityName>& locality_name = it->first;
2054
- auto& locality_state = it->second;
2055
- XdsClusterLocalityStats::Snapshot& locality_snapshot =
2056
- snapshot.locality_stats[locality_name];
2057
- locality_snapshot = std::move(locality_state.deleted_locality_stats);
2058
- if (locality_state.locality_stats != nullptr) {
2059
- locality_snapshot +=
2060
- locality_state.locality_stats->GetSnapshotAndReset();
2061
- GRPC_TRACE_LOG(xds_client, INFO)
2062
- << "[xds_client " << this
2063
- << "] cluster=" << cluster_key.first.c_str()
2064
- << " eds_service_name=" << cluster_key.second.c_str()
2065
- << " locality=" << locality_name->human_readable_string().c_str()
2066
- << " locality_stats=" << locality_state.locality_stats;
2067
- }
2068
- // If the only thing left in this entry was final snapshots from
2069
- // deleted locality stats objects, remove the entry.
2070
- if (locality_state.locality_stats == nullptr) {
2071
- it = load_report.locality_stats.erase(it);
2072
- } else {
2073
- ++it;
2074
- }
2075
- }
2076
- // Compute load report interval.
2077
- const Timestamp now = Timestamp::Now();
2078
- snapshot.load_report_interval = now - load_report.last_report_time;
2079
- load_report.last_report_time = now;
2080
- // Record snapshot.
2081
- if (record_stats) {
2082
- snapshot_map[cluster_key] = std::move(snapshot);
2083
- }
2084
- // If the only thing left in this entry was final snapshots from
2085
- // deleted stats objects, remove the entry.
2086
- if (load_report.locality_stats.empty() &&
2087
- load_report.drop_stats == nullptr) {
2088
- load_report_it = load_report_map.erase(load_report_it);
2089
- } else {
2090
- ++load_report_it;
2091
- }
2092
- }
2093
- return snapshot_map;
2094
- }
2095
-
2096
- namespace {
2097
-
2098
- google_protobuf_Timestamp* EncodeTimestamp(Timestamp value, upb_Arena* arena) {
2099
- google_protobuf_Timestamp* timestamp = google_protobuf_Timestamp_new(arena);
2100
- gpr_timespec timespec = value.as_timespec(GPR_CLOCK_REALTIME);
2101
- google_protobuf_Timestamp_set_seconds(timestamp, timespec.tv_sec);
2102
- google_protobuf_Timestamp_set_nanos(timestamp, timespec.tv_nsec);
2103
- return timestamp;
2104
- }
2105
-
2106
- void FillGenericXdsConfig(
2107
- const XdsApi::ResourceMetadata& metadata, upb_StringView type_url,
2108
- upb_StringView resource_name, upb_Arena* arena,
2109
- envoy_service_status_v3_ClientConfig_GenericXdsConfig* entry) {
2110
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_type_url(entry,
2111
- type_url);
2112
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_name(entry,
2113
- resource_name);
2114
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_client_status(
2115
- entry, metadata.client_status);
2116
- if (!metadata.serialized_proto.empty()) {
2117
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_version_info(
2118
- entry, StdStringToUpbString(metadata.version));
2119
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_last_updated(
2120
- entry, EncodeTimestamp(metadata.update_time, arena));
2121
- auto* any_field =
2122
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_mutable_xds_config(
2123
- entry, arena);
2124
- google_protobuf_Any_set_type_url(any_field, type_url);
2125
- google_protobuf_Any_set_value(
2126
- any_field, StdStringToUpbString(metadata.serialized_proto));
2127
- }
2128
- if (metadata.client_status == XdsApi::ResourceMetadata::NACKED) {
2129
- auto* update_failure_state = envoy_admin_v3_UpdateFailureState_new(arena);
2130
- envoy_admin_v3_UpdateFailureState_set_details(
2131
- update_failure_state, StdStringToUpbString(metadata.failed_details));
2132
- envoy_admin_v3_UpdateFailureState_set_version_info(
2133
- update_failure_state, StdStringToUpbString(metadata.failed_version));
2134
- envoy_admin_v3_UpdateFailureState_set_last_update_attempt(
2135
- update_failure_state,
2136
- EncodeTimestamp(metadata.failed_update_time, arena));
2137
- envoy_service_status_v3_ClientConfig_GenericXdsConfig_set_error_state(
2138
- entry, update_failure_state);
1938
+ void XdsClient::NotifyWatchersOnError(
1939
+ const ResourceState& resource_state,
1940
+ RefCountedPtr<ReadDelayHandle> read_delay_handle, WatcherSet watchers,
1941
+ absl::Status status) {
1942
+ if (watchers.empty()) watchers = resource_state.watchers();
1943
+ if (status.ok()) status = resource_state.failed_status();
1944
+ if (!resource_state.HasResource()) {
1945
+ NotifyWatchersOnResourceChanged(std::move(status), std::move(watchers),
1946
+ std::move(read_delay_handle));
1947
+ } else {
1948
+ NotifyWatchersOnAmbientError(std::move(status), std::move(watchers),
1949
+ std::move(read_delay_handle));
2139
1950
  }
2140
1951
  }
2141
1952
 
2142
- } // namespace
2143
-
2144
1953
  void XdsClient::DumpClientConfig(
2145
1954
  std::set<std::string>* string_pool, upb_Arena* arena,
2146
1955
  envoy_service_status_v3_ClientConfig* client_config) {
@@ -2148,70 +1957,51 @@ void XdsClient::DumpClientConfig(
2148
1957
  // Fill-in the node information
2149
1958
  auto* node =
2150
1959
  envoy_service_status_v3_ClientConfig_mutable_node(client_config, arena);
2151
- api_.PopulateNode(node, arena);
1960
+ PopulateXdsNode(bootstrap_->node(), user_agent_name_, user_agent_version_,
1961
+ node, arena);
2152
1962
  // Dump each resource.
2153
- for (const auto& a : authority_state_map_) { // authority
2154
- const std::string& authority = a.first;
2155
- for (const auto& t : a.second.resource_map) { // type
2156
- const XdsResourceType* type = t.first;
1963
+ for (const auto& [authority, authority_state] : authority_state_map_) {
1964
+ for (const auto& [type, resource_map] : authority_state.type_map) {
2157
1965
  auto it =
2158
1966
  string_pool
2159
1967
  ->emplace(absl::StrCat("type.googleapis.com/", type->type_url()))
2160
1968
  .first;
2161
1969
  upb_StringView type_url = StdStringToUpbString(*it);
2162
- for (const auto& r : t.second) { // resource id
1970
+ for (const auto& [resource_key, resource_state] : resource_map) {
1971
+ if (!resource_state.HasWatchers()) continue;
2163
1972
  auto it2 = string_pool
2164
1973
  ->emplace(ConstructFullXdsResourceName(
2165
- authority, type->type_url(), r.first))
1974
+ authority, type->type_url(), resource_key))
2166
1975
  .first;
2167
1976
  upb_StringView resource_name = StdStringToUpbString(*it2);
2168
1977
  envoy_service_status_v3_ClientConfig_GenericXdsConfig* entry =
2169
1978
  envoy_service_status_v3_ClientConfig_add_generic_xds_configs(
2170
1979
  client_config, arena);
2171
- FillGenericXdsConfig(r.second.meta, type_url, resource_name, arena,
2172
- entry);
1980
+ resource_state.FillGenericXdsConfig(type_url, resource_name, arena,
1981
+ entry);
2173
1982
  }
2174
1983
  }
2175
1984
  }
2176
1985
  }
2177
1986
 
2178
- namespace {
2179
-
2180
- absl::string_view CacheStateForEntry(const XdsApi::ResourceMetadata& metadata,
2181
- bool resource_cached) {
2182
- switch (metadata.client_status) {
2183
- case XdsApi::ResourceMetadata::REQUESTED:
2184
- return "requested";
2185
- case XdsApi::ResourceMetadata::DOES_NOT_EXIST:
2186
- return "does_not_exist";
2187
- case XdsApi::ResourceMetadata::ACKED:
2188
- return "acked";
2189
- case XdsApi::ResourceMetadata::NACKED:
2190
- return resource_cached ? "nacked_but_cached" : "nacked";
2191
- }
2192
- Crash("unknown resource state");
2193
- }
2194
-
2195
- } // namespace
2196
-
2197
1987
  void XdsClient::ReportResourceCounts(
2198
1988
  absl::FunctionRef<void(const ResourceCountLabels&, uint64_t)> func) {
2199
1989
  ResourceCountLabels labels;
2200
- for (const auto& a : authority_state_map_) { // authority
2201
- labels.xds_authority = a.first;
2202
- for (const auto& t : a.second.resource_map) { // type
2203
- labels.resource_type = t.first->type_url();
1990
+ for (const auto& [authority, authority_state] : authority_state_map_) {
1991
+ labels.xds_authority = authority;
1992
+ for (const auto& [type, resource_map] : authority_state.type_map) {
1993
+ labels.resource_type = type->type_url();
2204
1994
  // Count the number of entries in each state.
2205
1995
  std::map<absl::string_view, uint64_t> counts;
2206
- for (const auto& r : t.second) { // resource id
2207
- absl::string_view cache_state =
2208
- CacheStateForEntry(r.second.meta, r.second.resource != nullptr);
2209
- ++counts[cache_state];
1996
+ for (const auto& [_, resource_state] : resource_map) {
1997
+ if (resource_state.HasWatchers()) {
1998
+ ++counts[resource_state.CacheStateString()];
1999
+ }
2210
2000
  }
2211
2001
  // Report the count for each state.
2212
- for (const auto& c : counts) {
2213
- labels.cache_state = c.first;
2214
- func(labels, c.second);
2002
+ for (const auto& [state, count] : counts) {
2003
+ labels.cache_state = state;
2004
+ func(labels, count);
2215
2005
  }
2216
2006
  }
2217
2007
  }
@@ -2219,8 +2009,8 @@ void XdsClient::ReportResourceCounts(
2219
2009
 
2220
2010
  void XdsClient::ReportServerConnections(
2221
2011
  absl::FunctionRef<void(absl::string_view, bool)> func) {
2222
- for (const auto& p : xds_channel_map_) {
2223
- func(p.second->server_uri(), p.second->status().ok());
2012
+ for (const auto& [_, xds_channel] : xds_channel_map_) {
2013
+ func(xds_channel->server_uri(), xds_channel->status().ok());
2224
2014
  }
2225
2015
  }
2226
2016