grpc 1.64.0 → 1.68.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2325) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +127 -99
  3. data/include/grpc/compression.h +1 -2
  4. data/include/grpc/credentials.h +2 -3
  5. data/include/grpc/event_engine/README.md +1 -1
  6. data/include/grpc/event_engine/endpoint_config.h +2 -2
  7. data/include/grpc/event_engine/event_engine.h +33 -12
  8. data/include/grpc/event_engine/extensible.h +5 -2
  9. data/include/grpc/event_engine/internal/memory_allocator_impl.h +4 -4
  10. data/include/grpc/event_engine/internal/slice_cast.h +1 -1
  11. data/include/grpc/event_engine/memory_allocator.h +3 -4
  12. data/include/grpc/event_engine/memory_request.h +19 -2
  13. data/include/grpc/event_engine/slice.h +3 -5
  14. data/include/grpc/event_engine/slice_buffer.h +6 -8
  15. data/include/grpc/grpc.h +1 -2
  16. data/include/grpc/grpc_audit_logging.h +3 -3
  17. data/include/grpc/grpc_crl_provider.h +5 -5
  18. data/include/grpc/grpc_posix.h +1 -2
  19. data/include/grpc/grpc_security.h +1 -2
  20. data/include/grpc/impl/call.h +2 -2
  21. data/include/grpc/impl/channel_arg_names.h +8 -4
  22. data/include/grpc/impl/grpc_types.h +1 -2
  23. data/include/grpc/impl/slice_type.h +1 -2
  24. data/include/grpc/module.modulemap +1 -0
  25. data/include/grpc/passive_listener.h +62 -0
  26. data/include/grpc/support/alloc.h +1 -2
  27. data/include/grpc/support/json.h +1 -2
  28. data/include/grpc/support/log.h +37 -64
  29. data/include/grpc/support/metrics.h +21 -6
  30. data/include/grpc/support/port_platform.h +31 -1
  31. data/include/grpc/support/sync_generic.h +2 -4
  32. data/include/grpc/support/sync_posix.h +1 -2
  33. data/include/grpc/support/time.h +1 -2
  34. data/src/core/channelz/channel_trace.cc +6 -7
  35. data/src/core/channelz/channel_trace.h +6 -8
  36. data/src/core/channelz/channelz.cc +8 -10
  37. data/src/core/channelz/channelz.h +15 -17
  38. data/src/core/channelz/channelz_registry.cc +10 -11
  39. data/src/core/channelz/channelz_registry.h +4 -5
  40. data/src/core/client_channel/backup_poller.cc +24 -15
  41. data/src/core/client_channel/client_channel.cc +1426 -0
  42. data/src/core/client_channel/client_channel.h +245 -0
  43. data/src/core/client_channel/client_channel_factory.cc +2 -2
  44. data/src/core/client_channel/client_channel_factory.h +1 -2
  45. data/src/core/client_channel/client_channel_filter.cc +348 -861
  46. data/src/core/client_channel/client_channel_filter.h +23 -76
  47. data/src/core/client_channel/client_channel_internal.h +23 -9
  48. data/src/core/client_channel/client_channel_plugin.cc +2 -17
  49. data/src/core/client_channel/client_channel_service_config.cc +2 -3
  50. data/src/core/client_channel/client_channel_service_config.h +6 -8
  51. data/src/core/client_channel/config_selector.h +21 -22
  52. data/src/core/client_channel/connector.h +3 -3
  53. data/src/core/client_channel/direct_channel.cc +83 -0
  54. data/src/core/client_channel/direct_channel.h +101 -0
  55. data/src/core/client_channel/dynamic_filters.cc +16 -14
  56. data/src/core/client_channel/dynamic_filters.h +9 -10
  57. data/src/core/client_channel/global_subchannel_pool.cc +2 -2
  58. data/src/core/client_channel/global_subchannel_pool.h +2 -3
  59. data/src/core/client_channel/lb_metadata.cc +120 -0
  60. data/src/core/client_channel/lb_metadata.h +55 -0
  61. data/src/core/client_channel/load_balanced_call_destination.cc +273 -0
  62. data/src/core/client_channel/load_balanced_call_destination.h +48 -0
  63. data/src/core/client_channel/local_subchannel_pool.cc +2 -5
  64. data/src/core/client_channel/local_subchannel_pool.h +1 -1
  65. data/src/core/client_channel/retry_filter.cc +8 -17
  66. data/src/core/client_channel/retry_filter.h +6 -15
  67. data/src/core/client_channel/retry_filter_legacy_call_data.cc +206 -318
  68. data/src/core/client_channel/retry_filter_legacy_call_data.h +9 -14
  69. data/src/core/client_channel/retry_service_config.cc +9 -12
  70. data/src/core/client_channel/retry_service_config.h +5 -7
  71. data/src/core/client_channel/retry_throttle.cc +3 -4
  72. data/src/core/client_channel/retry_throttle.h +4 -7
  73. data/src/core/client_channel/subchannel.cc +282 -164
  74. data/src/core/client_channel/subchannel.h +48 -40
  75. data/src/core/client_channel/subchannel_interface_internal.h +1 -1
  76. data/src/core/client_channel/subchannel_pool_interface.cc +1 -5
  77. data/src/core/client_channel/subchannel_pool_interface.h +4 -7
  78. data/src/core/client_channel/subchannel_stream_client.cc +43 -59
  79. data/src/core/client_channel/subchannel_stream_client.h +10 -14
  80. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +22 -27
  81. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +3 -1
  82. data/src/core/ext/filters/backend_metrics/backend_metric_provider.h +7 -0
  83. data/src/core/ext/filters/census/grpc_context.cc +7 -10
  84. data/src/core/ext/filters/channel_idle/idle_filter_state.cc +1 -2
  85. data/src/core/ext/filters/channel_idle/idle_filter_state.h +0 -1
  86. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +34 -45
  87. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +12 -8
  88. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +16 -19
  89. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +4 -3
  90. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +2 -3
  91. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.h +6 -9
  92. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.cc +205 -0
  93. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.h +97 -0
  94. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.cc +80 -0
  95. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.h +86 -0
  96. data/src/core/ext/filters/http/client/http_client_filter.cc +14 -8
  97. data/src/core/ext/filters/http/client/http_client_filter.h +3 -1
  98. data/src/core/ext/filters/http/client_authority_filter.cc +8 -7
  99. data/src/core/ext/filters/http/client_authority_filter.h +3 -1
  100. data/src/core/ext/filters/http/http_filters_plugin.cc +0 -1
  101. data/src/core/ext/filters/http/message_compress/compression_filter.cc +48 -44
  102. data/src/core/ext/filters/http/message_compress/compression_filter.h +8 -4
  103. data/src/core/ext/filters/http/server/http_server_filter.cc +16 -13
  104. data/src/core/ext/filters/http/server/http_server_filter.h +3 -1
  105. data/src/core/ext/filters/message_size/message_size_filter.cc +32 -32
  106. data/src/core/ext/filters/message_size/message_size_filter.h +11 -9
  107. data/src/core/ext/filters/rbac/rbac_filter.cc +8 -11
  108. data/src/core/ext/filters/rbac/rbac_filter.h +3 -2
  109. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +16 -10
  110. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +2 -4
  111. data/src/core/ext/filters/stateful_session/stateful_session_filter.cc +13 -15
  112. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +5 -4
  113. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.cc +2 -3
  114. data/src/core/ext/filters/stateful_session/stateful_session_service_config_parser.h +5 -7
  115. data/src/core/ext/transport/chttp2/alpn/alpn.cc +2 -4
  116. data/src/core/ext/transport/chttp2/alpn/alpn.h +1 -2
  117. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +71 -101
  118. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +5 -11
  119. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +426 -314
  120. data/src/core/ext/transport/chttp2/server/chttp2_server.h +35 -2
  121. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +19 -32
  122. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -3
  123. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +1 -4
  124. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +1 -2
  125. data/src/core/ext/transport/chttp2/transport/call_tracer_wrapper.cc +53 -0
  126. data/src/core/ext/transport/chttp2/transport/call_tracer_wrapper.h +72 -0
  127. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +562 -516
  128. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +15 -16
  129. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +2 -3
  130. data/src/core/ext/transport/chttp2/transport/decode_huff.h +2 -2
  131. data/src/core/ext/transport/chttp2/transport/flow_control.cc +6 -11
  132. data/src/core/ext/transport/chttp2/transport/flow_control.h +2 -7
  133. data/src/core/ext/transport/chttp2/transport/frame.cc +2 -5
  134. data/src/core/ext/transport/chttp2/transport/frame.h +2 -3
  135. data/src/core/ext/transport/chttp2/transport/frame_data.cc +7 -13
  136. data/src/core/ext/transport/chttp2/transport/frame_data.h +4 -5
  137. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +3 -6
  138. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -2
  139. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +14 -19
  140. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -2
  141. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +17 -18
  142. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +6 -5
  143. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +20 -20
  144. data/src/core/ext/transport/chttp2/transport/frame_settings.h +3 -4
  145. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +10 -7
  146. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +4 -3
  147. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +2 -2
  148. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +14 -16
  149. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +16 -12
  150. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -3
  151. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +1 -2
  152. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +2 -4
  153. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +4 -7
  154. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +56 -51
  155. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +6 -6
  156. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +41 -16
  157. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +29 -10
  158. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +2 -3
  159. data/src/core/ext/transport/chttp2/transport/http2_settings.h +2 -4
  160. data/src/core/ext/transport/chttp2/transport/internal.h +46 -79
  161. data/src/core/ext/transport/chttp2/transport/parsing.cc +101 -109
  162. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +3 -3
  163. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +3 -3
  164. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +2 -5
  165. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +3 -7
  166. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +33 -18
  167. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +7 -8
  168. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +13 -16
  169. data/src/core/ext/transport/chttp2/transport/stream_lists.h +65 -0
  170. data/src/core/ext/transport/chttp2/transport/varint.cc +2 -2
  171. data/src/core/ext/transport/chttp2/transport/varint.h +1 -3
  172. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +2 -3
  173. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +2 -3
  174. data/src/core/ext/transport/chttp2/transport/writing.cc +145 -120
  175. data/src/core/ext/transport/inproc/inproc_transport.cc +149 -67
  176. data/src/core/ext/transport/inproc/inproc_transport.h +1 -3
  177. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +120 -121
  178. data/src/core/ext/transport/inproc/legacy_inproc_transport.h +0 -2
  179. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +43 -12
  180. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.c +36 -14
  181. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.h +7 -1
  182. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb.h +56 -24
  183. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.c +33 -15
  184. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.h +6 -1
  185. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb.h +47 -12
  186. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.c +39 -17
  187. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.h +7 -1
  188. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb.h +184 -51
  189. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.c +143 -65
  190. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.h +21 -1
  191. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb.h +8 -2
  192. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.c +13 -3
  193. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.h +4 -1
  194. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb.h +16 -3
  195. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.c +16 -6
  196. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.h +4 -1
  197. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb.h +8 -7
  198. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.c +7 -1
  199. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.h +3 -1
  200. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb.h +5 -4
  201. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.c +7 -1
  202. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.h +3 -1
  203. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb.h +5 -4
  204. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.c +7 -1
  205. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.h +3 -1
  206. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb.h +126 -79
  207. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.c +37 -25
  208. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.h +4 -1
  209. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb.h +6 -3
  210. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.c +9 -3
  211. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.h +3 -1
  212. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb.h +6 -5
  213. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.c +7 -1
  214. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.h +2 -1
  215. data/src/core/ext/upb-gen/envoy/annotations/resource.upb.h +13 -3
  216. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.c +12 -5
  217. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.h +3 -1
  218. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +88 -31
  219. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.c +103 -37
  220. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.h +18 -1
  221. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +541 -251
  222. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +247 -131
  223. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +26 -1
  224. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb.h +38 -11
  225. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.c +28 -14
  226. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.h +5 -1
  227. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +496 -138
  228. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +247 -122
  229. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.h +28 -1
  230. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +9 -4
  231. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +10 -4
  232. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.h +3 -1
  233. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +168 -24
  234. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +53 -26
  235. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.h +3 -1
  236. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +124 -32
  237. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +111 -49
  238. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.h +17 -1
  239. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +64 -24
  240. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +55 -21
  241. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.h +10 -1
  242. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb.h +8 -3
  243. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.c +10 -4
  244. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.h +3 -1
  245. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +752 -69
  246. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +304 -59
  247. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.h +36 -1
  248. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +64 -22
  249. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.c +52 -22
  250. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.h +9 -1
  251. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +5 -2
  252. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.c +9 -3
  253. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.h +3 -1
  254. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb.h +6 -3
  255. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.c +9 -3
  256. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.h +3 -1
  257. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb.h +8 -2
  258. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.c +13 -3
  259. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.h +4 -1
  260. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +198 -59
  261. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +111 -44
  262. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.h +16 -1
  263. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +193 -59
  264. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.c +90 -48
  265. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.h +11 -1
  266. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +10 -2
  267. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +10 -4
  268. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.h +3 -1
  269. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +7 -4
  270. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.c +9 -3
  271. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.h +3 -1
  272. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +228 -73
  273. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +139 -67
  274. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.h +18 -1
  275. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb.h +7 -4
  276. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.c +13 -3
  277. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.h +4 -1
  278. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb.h +12 -4
  279. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.c +14 -4
  280. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.h +4 -1
  281. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +13 -7
  282. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.c +13 -3
  283. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.h +4 -1
  284. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +20 -8
  285. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +16 -6
  286. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.h +4 -1
  287. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb.h +8 -3
  288. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.c +10 -4
  289. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.h +3 -1
  290. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +39 -8
  291. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +31 -13
  292. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.h +6 -1
  293. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +103 -31
  294. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.c +62 -30
  295. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.h +9 -1
  296. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb.h +278 -34
  297. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.c +78 -24
  298. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.h +9 -1
  299. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb.h +5 -2
  300. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.c +9 -3
  301. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.h +3 -1
  302. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +139 -44
  303. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.c +85 -42
  304. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.h +12 -1
  305. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +88 -26
  306. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.c +61 -31
  307. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.h +9 -1
  308. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb.h +90 -10
  309. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.c +23 -13
  310. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.h +3 -1
  311. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb.h +11 -4
  312. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.c +15 -5
  313. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.h +4 -1
  314. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb.h +11 -6
  315. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.c +10 -4
  316. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.h +3 -1
  317. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +48 -19
  318. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.c +52 -18
  319. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.h +10 -1
  320. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +65 -18
  321. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.c +64 -22
  322. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.h +12 -1
  323. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +156 -35
  324. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.c +95 -47
  325. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.h +13 -1
  326. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +58 -10
  327. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +30 -16
  328. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.h +5 -1
  329. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +705 -230
  330. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +454 -217
  331. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.h +60 -1
  332. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +17 -7
  333. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.c +20 -6
  334. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.h +5 -1
  335. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +97 -32
  336. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +86 -36
  337. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.h +14 -1
  338. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb.h +115 -13
  339. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.c +43 -12
  340. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.h +5 -1
  341. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +6 -3
  342. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +9 -3
  343. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.h +3 -1
  344. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +9 -4
  345. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.c +15 -5
  346. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.h +4 -1
  347. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb.h +7 -4
  348. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.c +9 -3
  349. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.h +3 -1
  350. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb.h +19 -12
  351. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.c +11 -5
  352. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.h +3 -1
  353. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +17 -5
  354. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +12 -6
  355. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.h +3 -1
  356. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb.h +5 -2
  357. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.c +9 -3
  358. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.h +3 -1
  359. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +14 -7
  360. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.c +16 -6
  361. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.h +4 -1
  362. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb.h +2 -1
  363. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.c +3 -1
  364. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.h +2 -1
  365. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb.h +16 -7
  366. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.c +17 -7
  367. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.h +4 -1
  368. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb.h +11 -8
  369. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.c +9 -3
  370. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.h +3 -1
  371. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +213 -99
  372. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +115 -48
  373. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.h +18 -1
  374. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +2 -1
  375. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.c +7 -1
  376. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.h +3 -1
  377. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +21 -8
  378. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.c +31 -9
  379. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.h +7 -1
  380. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +39 -19
  381. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.c +25 -11
  382. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.h +5 -1
  383. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb.h +444 -0
  384. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.c +135 -0
  385. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.h +38 -0
  386. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +53 -10
  387. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.c +27 -11
  388. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.h +4 -1
  389. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +26 -9
  390. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +18 -8
  391. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.h +4 -1
  392. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +10 -5
  393. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +15 -5
  394. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.h +4 -1
  395. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +324 -131
  396. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +189 -102
  397. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.h +23 -1
  398. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +5 -2
  399. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.c +9 -3
  400. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.h +3 -1
  401. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +20 -7
  402. 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 +14 -8
  403. 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 +3 -1
  404. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +28 -11
  405. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.c +35 -13
  406. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.h +7 -1
  407. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +3 -2
  408. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.c +7 -1
  409. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.h +3 -1
  410. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +19 -8
  411. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.c +13 -7
  412. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.h +3 -1
  413. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +5 -2
  414. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.c +9 -3
  415. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.h +3 -1
  416. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb.h +106 -0
  417. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.c +52 -0
  418. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.h +32 -0
  419. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +2 -1
  420. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.c +3 -1
  421. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.h +2 -1
  422. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +167 -28
  423. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +78 -32
  424. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.h +11 -1
  425. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +22 -9
  426. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.c +24 -10
  427. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.h +5 -1
  428. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +109 -36
  429. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +67 -37
  430. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.h +9 -1
  431. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +11 -3
  432. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.c +15 -5
  433. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.h +4 -1
  434. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +55 -17
  435. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.c +40 -22
  436. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.h +6 -1
  437. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb.h +2 -1
  438. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.c +7 -1
  439. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.h +3 -1
  440. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +119 -37
  441. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.c +95 -37
  442. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.h +16 -1
  443. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb.h +15 -5
  444. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.c +16 -6
  445. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.h +4 -1
  446. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +62 -21
  447. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +42 -20
  448. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.h +7 -1
  449. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb.h +7 -4
  450. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.c +9 -3
  451. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.h +3 -1
  452. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +13 -3
  453. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.c +24 -6
  454. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.h +6 -1
  455. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +6 -3
  456. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.c +9 -3
  457. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.h +3 -1
  458. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb.h +7 -6
  459. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.c +23 -1
  460. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.h +7 -1
  461. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +13 -5
  462. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.c +14 -4
  463. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.h +4 -1
  464. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb.h +10 -2
  465. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.c +10 -4
  466. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.h +3 -1
  467. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +6 -3
  468. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.c +9 -3
  469. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.h +3 -1
  470. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +5 -2
  471. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.c +9 -3
  472. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.h +3 -1
  473. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +13 -6
  474. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.c +21 -7
  475. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.h +5 -1
  476. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb.h +2 -1
  477. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.c +11 -1
  478. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.h +4 -1
  479. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +48 -7
  480. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.c +28 -7
  481. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.h +4 -1
  482. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +11 -3
  483. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.c +14 -4
  484. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.h +4 -1
  485. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +27 -9
  486. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +29 -11
  487. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.h +6 -1
  488. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +21 -7
  489. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.c +38 -8
  490. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.h +9 -1
  491. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +27 -14
  492. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.c +31 -9
  493. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.h +7 -1
  494. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +9 -4
  495. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.c +18 -4
  496. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.h +5 -1
  497. data/src/core/ext/upb-gen/envoy/type/v3/http.upb.h +2 -1
  498. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.c +3 -1
  499. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.h +2 -1
  500. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb.h +3 -2
  501. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.c +7 -1
  502. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.h +3 -1
  503. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb.h +5 -4
  504. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.c +11 -1
  505. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.h +4 -1
  506. data/src/core/ext/upb-gen/envoy/type/v3/range.upb.h +8 -7
  507. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.c +15 -1
  508. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.h +5 -1
  509. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +11 -6
  510. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.c +14 -4
  511. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.h +4 -1
  512. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb.h +2 -1
  513. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.c +3 -1
  514. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.h +2 -1
  515. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb.h +5 -4
  516. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.c +7 -1
  517. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.h +3 -1
  518. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb.h +9 -4
  519. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.c +10 -4
  520. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.h +3 -1
  521. data/src/core/ext/upb-gen/google/api/annotations.upb.h +12 -2
  522. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.c +4 -1
  523. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.h +2 -1
  524. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +132 -33
  525. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +108 -43
  526. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.h +15 -1
  527. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +522 -66
  528. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +191 -57
  529. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.h +20 -1
  530. data/src/core/ext/upb-gen/google/api/http.upb.h +26 -13
  531. data/src/core/ext/upb-gen/google/api/http.upb_minitable.c +20 -6
  532. data/src/core/ext/upb-gen/google/api/http.upb_minitable.h +5 -1
  533. data/src/core/ext/upb-gen/google/api/httpbody.upb.h +9 -3
  534. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.c +9 -3
  535. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.h +3 -1
  536. data/src/core/ext/upb-gen/google/protobuf/any.upb.h +4 -3
  537. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.c +7 -1
  538. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.h +3 -1
  539. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +579 -178
  540. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +292 -131
  541. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +36 -1
  542. data/src/core/ext/upb-gen/google/protobuf/duration.upb.h +4 -3
  543. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.c +7 -1
  544. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.h +3 -1
  545. data/src/core/ext/upb-gen/google/protobuf/empty.upb.h +2 -1
  546. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.c +7 -1
  547. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.h +3 -1
  548. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +29 -7
  549. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.c +28 -10
  550. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.h +6 -1
  551. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb.h +4 -3
  552. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.c +7 -1
  553. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.h +3 -1
  554. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb.h +11 -10
  555. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.c +39 -1
  556. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.h +11 -1
  557. data/src/core/ext/upb-gen/google/rpc/status.upb.h +9 -3
  558. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.c +9 -3
  559. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.h +3 -1
  560. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb.h +18 -11
  561. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.c +23 -5
  562. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.h +6 -1
  563. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +16 -7
  564. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.c +14 -4
  565. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.h +4 -1
  566. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +95 -36
  567. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +79 -29
  568. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.h +14 -1
  569. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +10 -5
  570. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +14 -4
  571. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.h +4 -1
  572. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb.h +4 -3
  573. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.c +11 -1
  574. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.h +4 -1
  575. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +44 -19
  576. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.c +53 -15
  577. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.h +11 -1
  578. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +12 -5
  579. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.c +17 -3
  580. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.h +5 -1
  581. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +69 -16
  582. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.c +56 -18
  583. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.h +11 -1
  584. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb.h +56 -10
  585. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.c +26 -7
  586. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.h +5 -1
  587. data/src/core/ext/upb-gen/udpa/annotations/security.upb.h +14 -4
  588. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.c +12 -5
  589. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.h +3 -1
  590. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb.h +3 -2
  591. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.c +4 -1
  592. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.h +2 -1
  593. data/src/core/ext/upb-gen/udpa/annotations/status.upb.h +14 -4
  594. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.c +12 -5
  595. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.h +3 -1
  596. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb.h +13 -3
  597. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.c +12 -5
  598. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.h +3 -1
  599. data/src/core/ext/upb-gen/validate/validate.upb.h +259 -167
  600. data/src/core/ext/upb-gen/validate/validate.upb_minitable.c +178 -80
  601. data/src/core/ext/upb-gen/validate/validate.upb_minitable.h +25 -1
  602. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb.h +56 -10
  603. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.c +26 -7
  604. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.h +5 -1
  605. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb.h +14 -4
  606. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.c +12 -5
  607. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.h +3 -1
  608. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb.h +3 -2
  609. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.c +4 -1
  610. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.h +2 -1
  611. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb.h +37 -9
  612. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.c +29 -8
  613. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.h +6 -1
  614. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb.h +13 -3
  615. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.c +12 -5
  616. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.h +3 -1
  617. data/src/core/ext/upb-gen/xds/core/v3/authority.upb.h +3 -2
  618. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.c +7 -1
  619. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.h +3 -1
  620. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb.h +6 -3
  621. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.c +9 -3
  622. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.h +3 -1
  623. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +13 -6
  624. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.c +16 -6
  625. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.h +4 -1
  626. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb.h +8 -1
  627. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.c +13 -3
  628. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.h +4 -1
  629. data/src/core/ext/upb-gen/xds/core/v3/extension.upb.h +6 -3
  630. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.c +9 -3
  631. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.h +3 -1
  632. data/src/core/ext/upb-gen/xds/core/v3/resource.upb.h +9 -4
  633. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.c +10 -4
  634. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.h +3 -1
  635. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +18 -8
  636. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.c +16 -6
  637. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.h +4 -1
  638. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb.h +8 -5
  639. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.c +9 -3
  640. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.h +3 -1
  641. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +26 -7
  642. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.c +23 -5
  643. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.h +6 -1
  644. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb.h +5 -2
  645. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.c +9 -3
  646. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.h +3 -1
  647. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +6 -3
  648. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +9 -3
  649. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.h +3 -1
  650. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb.h +10 -2
  651. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.c +15 -5
  652. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.h +4 -1
  653. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb.h +2 -1
  654. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.c +7 -1
  655. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.h +3 -1
  656. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb.h +16 -3
  657. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.c +16 -6
  658. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.h +4 -1
  659. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +78 -19
  660. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.c +75 -33
  661. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.h +12 -1
  662. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb.h +41 -4
  663. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.c +42 -16
  664. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.h +8 -1
  665. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +6 -3
  666. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.c +13 -3
  667. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.h +4 -1
  668. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +15 -7
  669. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.c +15 -5
  670. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.h +4 -1
  671. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +14 -5
  672. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.c +17 -7
  673. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.h +4 -1
  674. data/src/core/ext/upb-gen/xds/type/v3/range.upb.h +8 -7
  675. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.c +15 -1
  676. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.h +5 -1
  677. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb.h +6 -3
  678. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.c +9 -3
  679. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.h +3 -1
  680. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.c +2 -1
  681. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.h +2 -1
  682. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.c +2 -1
  683. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.h +2 -1
  684. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.c +2 -1
  685. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.h +2 -1
  686. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.c +2 -1
  687. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.h +2 -1
  688. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.c +2 -1
  689. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.h +2 -1
  690. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.c +2 -1
  691. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.h +2 -1
  692. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.c +2 -1
  693. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.h +2 -1
  694. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.c +2 -1
  695. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.h +2 -1
  696. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.c +2 -1
  697. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.h +2 -1
  698. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +88 -82
  699. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.h +2 -1
  700. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.c +2 -1
  701. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.h +2 -1
  702. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.c +2 -1
  703. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.h +2 -1
  704. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.c +2 -1
  705. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.h +2 -1
  706. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +63 -61
  707. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.h +2 -1
  708. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +223 -211
  709. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +7 -1
  710. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +2 -1
  711. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +2 -1
  712. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +319 -298
  713. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +7 -1
  714. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +2 -1
  715. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.h +2 -1
  716. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +116 -106
  717. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.h +2 -1
  718. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +2 -1
  719. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.h +2 -1
  720. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +2 -1
  721. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.h +2 -1
  722. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.c +2 -1
  723. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.h +2 -1
  724. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +187 -141
  725. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +27 -1
  726. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +12 -12
  727. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.h +2 -1
  728. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.c +2 -1
  729. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.h +2 -1
  730. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.c +2 -1
  731. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.h +2 -1
  732. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.c +2 -1
  733. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.h +2 -1
  734. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +175 -165
  735. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.h +2 -1
  736. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +199 -188
  737. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.h +2 -1
  738. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +2 -1
  739. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +2 -1
  740. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +2 -1
  741. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.h +2 -1
  742. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +231 -223
  743. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.h +2 -1
  744. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.c +2 -1
  745. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.h +2 -1
  746. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.c +2 -1
  747. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.h +2 -1
  748. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.c +2 -1
  749. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.h +2 -1
  750. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +2 -1
  751. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +2 -1
  752. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.c +2 -1
  753. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.h +2 -1
  754. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +2 -1
  755. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.h +2 -1
  756. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +41 -37
  757. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +2 -1
  758. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +124 -94
  759. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +7 -1
  760. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.c +2 -1
  761. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.h +2 -1
  762. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +43 -40
  763. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.h +2 -1
  764. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.c +2 -1
  765. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.h +2 -1
  766. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +22 -13
  767. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.h +2 -1
  768. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.c +2 -1
  769. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.h +2 -1
  770. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.c +2 -1
  771. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.h +2 -1
  772. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.c +2 -1
  773. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.h +2 -1
  774. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.c +2 -1
  775. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.h +2 -1
  776. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +71 -66
  777. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.h +2 -1
  778. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +2 -1
  779. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.h +2 -1
  780. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +613 -605
  781. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.h +2 -1
  782. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.c +2 -1
  783. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.h +2 -1
  784. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +2 -1
  785. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.h +2 -1
  786. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +32 -21
  787. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +7 -1
  788. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +20 -18
  789. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.h +2 -1
  790. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.c +2 -1
  791. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.h +2 -1
  792. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.c +2 -1
  793. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.h +2 -1
  794. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +64 -60
  795. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.h +2 -1
  796. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +2 -1
  797. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.h +2 -1
  798. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.c +2 -1
  799. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.h +2 -1
  800. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.c +2 -1
  801. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.h +2 -1
  802. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.c +2 -1
  803. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.h +2 -1
  804. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.c +2 -1
  805. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.h +2 -1
  806. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +23 -21
  807. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.h +2 -1
  808. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +147 -143
  809. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.h +2 -1
  810. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +2 -1
  811. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +2 -1
  812. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +2 -1
  813. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +2 -1
  814. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +2 -1
  815. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +2 -1
  816. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +87 -0
  817. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +48 -0
  818. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +38 -34
  819. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +2 -1
  820. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +2 -1
  821. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.h +2 -1
  822. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +2 -1
  823. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +2 -1
  824. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +292 -289
  825. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +2 -1
  826. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +2 -1
  827. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +2 -1
  828. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.c +53 -0
  829. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.h +33 -0
  830. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +2 -1
  831. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +2 -1
  832. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +84 -76
  833. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +7 -1
  834. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +2 -1
  835. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +2 -1
  836. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +2 -1
  837. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +2 -1
  838. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +2 -1
  839. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +2 -1
  840. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.c +2 -1
  841. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.h +2 -1
  842. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.c +2 -1
  843. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.h +2 -1
  844. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.c +2 -1
  845. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.h +2 -1
  846. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.c +2 -1
  847. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.h +2 -1
  848. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +2 -1
  849. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.h +2 -1
  850. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.c +2 -1
  851. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.h +2 -1
  852. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.c +2 -1
  853. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.h +2 -1
  854. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.c +2 -1
  855. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.h +2 -1
  856. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  857. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.h +2 -1
  858. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.c +2 -1
  859. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.h +2 -1
  860. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.c +2 -1
  861. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.h +2 -1
  862. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.c +2 -1
  863. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.h +2 -1
  864. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.c +2 -1
  865. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.h +2 -1
  866. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.c +2 -1
  867. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.h +2 -1
  868. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.c +2 -1
  869. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.h +2 -1
  870. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +41 -34
  871. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.h +2 -1
  872. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.c +2 -1
  873. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.h +2 -1
  874. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +2 -1
  875. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +2 -1
  876. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.c +2 -1
  877. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.h +2 -1
  878. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.c +2 -1
  879. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.h +2 -1
  880. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.c +2 -1
  881. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.h +2 -1
  882. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.c +2 -1
  883. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.h +2 -1
  884. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.c +2 -1
  885. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.h +2 -1
  886. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.c +2 -1
  887. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.h +2 -1
  888. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.c +2 -1
  889. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.h +2 -1
  890. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.c +2 -1
  891. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.h +2 -1
  892. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.c +2 -1
  893. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.h +2 -1
  894. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.c +2 -1
  895. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.h +2 -1
  896. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.c +2 -1
  897. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.h +2 -1
  898. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.c +2 -1
  899. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.h +2 -1
  900. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +110 -108
  901. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.h +2 -1
  902. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +103 -79
  903. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +12 -1
  904. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.c +2 -1
  905. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.h +2 -1
  906. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.c +2 -1
  907. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.h +2 -1
  908. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.c +2 -1
  909. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.h +2 -1
  910. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +283 -257
  911. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +7 -1
  912. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.c +2 -1
  913. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.h +2 -1
  914. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.c +2 -1
  915. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.h +2 -1
  916. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.c +2 -1
  917. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.h +2 -1
  918. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.c +2 -1
  919. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.h +2 -1
  920. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.c +2 -1
  921. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.h +2 -1
  922. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.c +2 -1
  923. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.h +2 -1
  924. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.c +2 -1
  925. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.h +2 -1
  926. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +2 -1
  927. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +2 -1
  928. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.c +2 -1
  929. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.h +2 -1
  930. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.c +2 -1
  931. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.h +2 -1
  932. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.c +2 -1
  933. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.h +2 -1
  934. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.c +2 -1
  935. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.h +2 -1
  936. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.c +2 -1
  937. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.h +2 -1
  938. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.c +2 -1
  939. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.h +2 -1
  940. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.c +2 -1
  941. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.h +2 -1
  942. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.c +2 -1
  943. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.h +2 -1
  944. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.c +2 -1
  945. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.h +2 -1
  946. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.c +2 -1
  947. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.h +2 -1
  948. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.c +2 -1
  949. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.h +2 -1
  950. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.c +2 -1
  951. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.h +2 -1
  952. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.c +2 -1
  953. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.h +2 -1
  954. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.c +2 -1
  955. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.h +2 -1
  956. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.c +2 -1
  957. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.h +2 -1
  958. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.c +2 -1
  959. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.h +2 -1
  960. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.c +2 -1
  961. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.h +2 -1
  962. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.c +2 -1
  963. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.h +2 -1
  964. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.c +2 -1
  965. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.h +2 -1
  966. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +2 -1
  967. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.h +2 -1
  968. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.c +2 -1
  969. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.h +2 -1
  970. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  971. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.h +2 -1
  972. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.c +2 -1
  973. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.h +2 -1
  974. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.c +2 -1
  975. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.h +2 -1
  976. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.c +2 -1
  977. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.h +2 -1
  978. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.c +2 -1
  979. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.h +2 -1
  980. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.c +2 -1
  981. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.h +2 -1
  982. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.c +2 -1
  983. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.h +2 -1
  984. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.c +2 -1
  985. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.h +2 -1
  986. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.c +2 -1
  987. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.h +2 -1
  988. data/src/core/filter/blackboard.cc +33 -0
  989. data/src/core/filter/blackboard.h +70 -0
  990. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.cc +13 -12
  991. data/src/core/handshaker/handshaker.cc +127 -159
  992. data/src/core/handshaker/handshaker.h +58 -52
  993. data/src/core/handshaker/handshaker_registry.cc +1 -2
  994. data/src/core/handshaker/handshaker_registry.h +2 -2
  995. data/src/core/handshaker/http_connect/http_connect_handshaker.cc +113 -159
  996. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +30 -37
  997. data/src/core/handshaker/http_connect/http_proxy_mapper.h +2 -3
  998. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.cc +57 -0
  999. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.h +46 -0
  1000. data/src/core/handshaker/proxy_mapper.h +2 -3
  1001. data/src/core/handshaker/proxy_mapper_registry.cc +2 -2
  1002. data/src/core/handshaker/proxy_mapper_registry.h +2 -3
  1003. data/src/core/handshaker/security/secure_endpoint.cc +95 -82
  1004. data/src/core/handshaker/security/secure_endpoint.h +6 -7
  1005. data/src/core/handshaker/security/security_handshaker.cc +166 -220
  1006. data/src/core/handshaker/security/security_handshaker.h +2 -3
  1007. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +47 -61
  1008. data/src/core/lib/address_utils/parse_address.cc +30 -43
  1009. data/src/core/lib/address_utils/parse_address.h +2 -4
  1010. data/src/core/lib/address_utils/sockaddr_utils.cc +9 -12
  1011. data/src/core/lib/address_utils/sockaddr_utils.h +1 -3
  1012. data/src/core/lib/channel/call_finalization.h +2 -2
  1013. data/src/core/lib/channel/channel_args.cc +17 -23
  1014. data/src/core/lib/channel/channel_args.h +34 -20
  1015. data/src/core/lib/channel/channel_args_preconditioning.cc +2 -2
  1016. data/src/core/lib/channel/channel_args_preconditioning.h +3 -3
  1017. data/src/core/lib/channel/channel_stack.cc +13 -76
  1018. data/src/core/lib/channel/channel_stack.h +26 -61
  1019. data/src/core/lib/channel/channel_stack_builder.cc +2 -2
  1020. data/src/core/lib/channel/channel_stack_builder.h +3 -9
  1021. data/src/core/lib/channel/channel_stack_builder_impl.cc +5 -150
  1022. data/src/core/lib/channel/channel_stack_builder_impl.h +14 -4
  1023. data/src/core/lib/channel/connected_channel.cc +46 -688
  1024. data/src/core/lib/channel/promise_based_filter.cc +180 -250
  1025. data/src/core/lib/channel/promise_based_filter.h +173 -509
  1026. data/src/core/lib/channel/status_util.cc +2 -4
  1027. data/src/core/lib/channel/status_util.h +3 -3
  1028. data/src/core/lib/compression/compression.cc +7 -9
  1029. data/src/core/lib/compression/compression_internal.cc +5 -8
  1030. data/src/core/lib/compression/compression_internal.h +3 -5
  1031. data/src/core/lib/compression/message_compress.cc +9 -12
  1032. data/src/core/lib/config/config_vars.cc +15 -18
  1033. data/src/core/lib/config/config_vars.h +10 -13
  1034. data/src/core/lib/config/config_vars_non_generated.cc +2 -2
  1035. data/src/core/lib/config/core_configuration.cc +2 -3
  1036. data/src/core/lib/config/core_configuration.h +2 -4
  1037. data/src/core/lib/config/load_config.cc +2 -4
  1038. data/src/core/lib/config/load_config.h +1 -2
  1039. data/src/core/lib/debug/trace.cc +47 -65
  1040. data/src/core/lib/debug/trace.h +2 -97
  1041. data/src/core/lib/debug/trace_flags.cc +242 -0
  1042. data/src/core/lib/debug/trace_flags.h +131 -0
  1043. data/src/core/lib/debug/trace_impl.h +125 -0
  1044. data/src/core/lib/event_engine/ares_resolver.cc +151 -75
  1045. data/src/core/lib/event_engine/ares_resolver.h +13 -20
  1046. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +13 -16
  1047. data/src/core/lib/event_engine/cf_engine/cf_engine.h +1 -1
  1048. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +44 -31
  1049. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +4 -6
  1050. data/src/core/lib/event_engine/cf_engine/cftype_unique_ref.h +1 -1
  1051. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +19 -26
  1052. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +3 -5
  1053. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +3 -4
  1054. data/src/core/lib/event_engine/channel_args_endpoint_config.h +2 -3
  1055. data/src/core/lib/event_engine/common_closures.h +3 -3
  1056. data/src/core/lib/event_engine/default_event_engine.cc +12 -14
  1057. data/src/core/lib/event_engine/default_event_engine.h +3 -3
  1058. data/src/core/lib/event_engine/default_event_engine_factory.cc +2 -2
  1059. data/src/core/lib/event_engine/default_event_engine_factory.h +2 -2
  1060. data/src/core/lib/event_engine/event_engine.cc +35 -4
  1061. data/src/core/lib/event_engine/event_engine_context.h +4 -2
  1062. data/src/core/lib/event_engine/extensions/can_track_errors.h +2 -2
  1063. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +1 -2
  1064. data/src/core/lib/event_engine/extensions/supports_fd.h +27 -3
  1065. data/src/core/lib/event_engine/extensions/tcp_trace.h +42 -0
  1066. data/src/core/lib/event_engine/forkable.cc +6 -8
  1067. data/src/core/lib/event_engine/forkable.h +2 -14
  1068. data/src/core/lib/event_engine/grpc_polled_fd.h +3 -4
  1069. data/src/core/lib/event_engine/handle_containers.h +2 -3
  1070. data/src/core/lib/event_engine/memory_allocator_factory.h +3 -4
  1071. data/src/core/lib/event_engine/poller.h +2 -2
  1072. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +21 -23
  1073. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +8 -9
  1074. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +13 -17
  1075. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +4 -5
  1076. data/src/core/lib/event_engine/posix_engine/event_poller.h +3 -4
  1077. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +3 -4
  1078. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +2 -2
  1079. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +4 -6
  1080. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +4 -4
  1081. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +1 -2
  1082. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +5 -7
  1083. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +2 -3
  1084. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +3 -4
  1085. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +2 -3
  1086. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +73 -79
  1087. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +11 -12
  1088. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +74 -55
  1089. data/src/core/lib/event_engine/posix_engine/posix_engine.h +18 -14
  1090. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +3 -3
  1091. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +23 -27
  1092. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +14 -13
  1093. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +22 -28
  1094. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +1 -2
  1095. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +44 -38
  1096. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +10 -10
  1097. data/src/core/lib/event_engine/posix_engine/timer.cc +5 -5
  1098. data/src/core/lib/event_engine/posix_engine/timer.h +5 -7
  1099. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +1 -2
  1100. data/src/core/lib/event_engine/posix_engine/timer_heap.h +2 -2
  1101. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +12 -21
  1102. data/src/core/lib/event_engine/posix_engine/timer_manager.h +5 -7
  1103. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +6 -8
  1104. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +3 -5
  1105. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +5 -6
  1106. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +2 -3
  1107. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +4 -5
  1108. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +2 -3
  1109. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +2 -2
  1110. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +2 -3
  1111. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +2 -2
  1112. data/src/core/lib/event_engine/query_extensions.h +2 -2
  1113. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +3 -5
  1114. data/src/core/lib/event_engine/resolved_address.cc +5 -5
  1115. data/src/core/lib/event_engine/shim.cc +1 -1
  1116. data/src/core/lib/event_engine/slice.cc +3 -6
  1117. data/src/core/lib/event_engine/slice_buffer.cc +1 -2
  1118. data/src/core/lib/event_engine/tcp_socket_utils.cc +9 -12
  1119. data/src/core/lib/event_engine/tcp_socket_utils.h +3 -3
  1120. data/src/core/lib/event_engine/thread_local.h +1 -1
  1121. data/src/core/lib/event_engine/thread_pool/thread_count.cc +5 -7
  1122. data/src/core/lib/event_engine/thread_pool/thread_count.h +6 -7
  1123. data/src/core/lib/event_engine/thread_pool/thread_pool.h +2 -4
  1124. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +2 -3
  1125. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +39 -46
  1126. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +10 -15
  1127. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +50 -23
  1128. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +9 -8
  1129. data/src/core/lib/event_engine/time_util.cc +2 -2
  1130. data/src/core/lib/event_engine/time_util.h +1 -2
  1131. data/src/core/lib/event_engine/utils.cc +19 -5
  1132. data/src/core/lib/event_engine/utils.h +10 -4
  1133. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +125 -100
  1134. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.h +4 -6
  1135. data/src/core/lib/event_engine/windows/iocp.cc +14 -14
  1136. data/src/core/lib/event_engine/windows/iocp.h +2 -3
  1137. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.cc +4 -6
  1138. data/src/core/lib/event_engine/windows/win_socket.cc +42 -33
  1139. data/src/core/lib/event_engine/windows/win_socket.h +8 -10
  1140. data/src/core/lib/event_engine/windows/windows_endpoint.cc +26 -27
  1141. data/src/core/lib/event_engine/windows/windows_engine.cc +242 -134
  1142. data/src/core/lib/event_engine/windows/windows_engine.h +143 -33
  1143. data/src/core/lib/event_engine/windows/windows_listener.cc +22 -37
  1144. data/src/core/lib/event_engine/windows/windows_listener.h +4 -5
  1145. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +3 -3
  1146. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +3 -5
  1147. data/src/core/lib/event_engine/work_queue/work_queue.h +2 -3
  1148. data/src/core/lib/experiments/config.cc +54 -27
  1149. data/src/core/lib/experiments/config.h +56 -3
  1150. data/src/core/lib/experiments/experiments.cc +159 -293
  1151. data/src/core/lib/experiments/experiments.h +84 -124
  1152. data/src/core/lib/iomgr/buffer_list.cc +5 -5
  1153. data/src/core/lib/iomgr/buffer_list.h +2 -3
  1154. data/src/core/lib/iomgr/call_combiner.cc +39 -66
  1155. data/src/core/lib/iomgr/call_combiner.h +12 -16
  1156. data/src/core/lib/iomgr/cfstream_handle.cc +14 -20
  1157. data/src/core/lib/iomgr/cfstream_handle.h +1 -1
  1158. data/src/core/lib/iomgr/closure.cc +2 -2
  1159. data/src/core/lib/iomgr/closure.h +12 -19
  1160. data/src/core/lib/iomgr/combiner.cc +33 -48
  1161. data/src/core/lib/iomgr/combiner.h +1 -4
  1162. data/src/core/lib/iomgr/endpoint.cc +0 -6
  1163. data/src/core/lib/iomgr/endpoint.h +3 -4
  1164. data/src/core/lib/iomgr/endpoint_cfstream.cc +40 -73
  1165. data/src/core/lib/iomgr/endpoint_pair_posix.cc +3 -6
  1166. data/src/core/lib/iomgr/endpoint_pair_windows.cc +6 -8
  1167. data/src/core/lib/iomgr/error.cc +22 -32
  1168. data/src/core/lib/iomgr/error.h +7 -10
  1169. data/src/core/lib/iomgr/error_cfstream.cc +1 -3
  1170. data/src/core/lib/iomgr/ev_apple.cc +15 -23
  1171. data/src/core/lib/iomgr/ev_epoll1_linux.cc +67 -113
  1172. data/src/core/lib/iomgr/ev_poll_posix.cc +53 -53
  1173. data/src/core/lib/iomgr/ev_posix.cc +66 -57
  1174. data/src/core/lib/iomgr/ev_posix.h +9 -12
  1175. data/src/core/lib/iomgr/event_engine_shims/closure.cc +10 -13
  1176. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -2
  1177. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +33 -51
  1178. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +2 -2
  1179. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +9 -13
  1180. data/src/core/lib/iomgr/exec_ctx.cc +10 -14
  1181. data/src/core/lib/iomgr/exec_ctx.h +33 -25
  1182. data/src/core/lib/iomgr/executor.cc +55 -53
  1183. data/src/core/lib/iomgr/executor.h +2 -2
  1184. data/src/core/lib/iomgr/fork_posix.cc +11 -15
  1185. data/src/core/lib/iomgr/fork_windows.cc +3 -2
  1186. data/src/core/lib/iomgr/internal_errqueue.cc +4 -4
  1187. data/src/core/lib/iomgr/iocp_windows.cc +8 -10
  1188. data/src/core/lib/iomgr/iomgr.cc +17 -23
  1189. data/src/core/lib/iomgr/iomgr.h +1 -2
  1190. data/src/core/lib/iomgr/iomgr_internal.cc +1 -2
  1191. data/src/core/lib/iomgr/iomgr_internal.h +1 -2
  1192. data/src/core/lib/iomgr/iomgr_windows.cc +1 -4
  1193. data/src/core/lib/iomgr/lockfree_event.cc +10 -20
  1194. data/src/core/lib/iomgr/polling_entity.cc +13 -7
  1195. data/src/core/lib/iomgr/pollset.h +0 -2
  1196. data/src/core/lib/iomgr/pollset_set_windows.cc +1 -2
  1197. data/src/core/lib/iomgr/pollset_windows.cc +2 -6
  1198. data/src/core/lib/iomgr/port.h +2 -2
  1199. data/src/core/lib/iomgr/resolve_address.cc +3 -5
  1200. data/src/core/lib/iomgr/resolve_address.h +4 -6
  1201. data/src/core/lib/iomgr/resolve_address_impl.h +1 -2
  1202. data/src/core/lib/iomgr/resolve_address_posix.cc +12 -21
  1203. data/src/core/lib/iomgr/resolve_address_posix.h +2 -2
  1204. data/src/core/lib/iomgr/resolve_address_windows.cc +9 -12
  1205. data/src/core/lib/iomgr/resolve_address_windows.h +2 -2
  1206. data/src/core/lib/iomgr/resolved_address.h +1 -2
  1207. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +3 -6
  1208. data/src/core/lib/iomgr/socket_factory_posix.cc +1 -1
  1209. data/src/core/lib/iomgr/socket_mutator.cc +2 -3
  1210. data/src/core/lib/iomgr/socket_mutator.h +1 -2
  1211. data/src/core/lib/iomgr/socket_utils.h +1 -2
  1212. data/src/core/lib/iomgr/socket_utils_common_posix.cc +43 -52
  1213. data/src/core/lib/iomgr/socket_utils_linux.cc +1 -3
  1214. data/src/core/lib/iomgr/socket_utils_posix.cc +4 -7
  1215. data/src/core/lib/iomgr/socket_utils_windows.cc +1 -3
  1216. data/src/core/lib/iomgr/socket_windows.cc +7 -11
  1217. data/src/core/lib/iomgr/socket_windows.h +1 -2
  1218. data/src/core/lib/iomgr/tcp_client_cfstream.cc +12 -20
  1219. data/src/core/lib/iomgr/tcp_client_posix.cc +17 -30
  1220. data/src/core/lib/iomgr/tcp_client_windows.cc +5 -10
  1221. data/src/core/lib/iomgr/tcp_posix.cc +85 -155
  1222. data/src/core/lib/iomgr/tcp_posix.h +0 -2
  1223. data/src/core/lib/iomgr/tcp_server.h +2 -2
  1224. data/src/core/lib/iomgr/tcp_server_posix.cc +40 -58
  1225. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -3
  1226. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +7 -11
  1227. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +9 -11
  1228. data/src/core/lib/iomgr/tcp_server_windows.cc +17 -25
  1229. data/src/core/lib/iomgr/tcp_windows.cc +32 -62
  1230. data/src/core/lib/iomgr/timer.h +2 -2
  1231. data/src/core/lib/iomgr/timer_generic.cc +71 -104
  1232. data/src/core/lib/iomgr/timer_heap.cc +2 -3
  1233. data/src/core/lib/iomgr/timer_manager.cc +25 -43
  1234. data/src/core/lib/iomgr/timer_manager.h +1 -2
  1235. data/src/core/lib/iomgr/unix_sockets_posix.cc +4 -6
  1236. data/src/core/lib/iomgr/unix_sockets_posix.h +3 -4
  1237. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -4
  1238. data/src/core/lib/iomgr/vsock.cc +3 -6
  1239. data/src/core/lib/iomgr/vsock.h +3 -4
  1240. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +2 -4
  1241. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +5 -6
  1242. data/src/core/lib/promise/activity.cc +2 -4
  1243. data/src/core/lib/promise/activity.h +48 -17
  1244. data/src/core/lib/promise/all_ok.h +17 -11
  1245. data/src/core/lib/promise/arena_promise.h +2 -4
  1246. data/src/core/lib/promise/cancel_callback.h +34 -6
  1247. data/src/core/lib/promise/context.h +19 -10
  1248. data/src/core/lib/promise/detail/basic_seq.h +2 -3
  1249. data/src/core/lib/promise/detail/join_state.h +556 -762
  1250. data/src/core/lib/promise/detail/promise_factory.h +46 -30
  1251. data/src/core/lib/promise/detail/promise_like.h +29 -14
  1252. data/src/core/lib/promise/detail/seq_state.h +1314 -1977
  1253. data/src/core/lib/promise/detail/status.h +36 -15
  1254. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +2 -3
  1255. data/src/core/lib/promise/for_each.h +34 -37
  1256. data/src/core/lib/promise/if.h +23 -19
  1257. data/src/core/lib/promise/interceptor_list.h +21 -35
  1258. data/src/core/lib/promise/latch.h +19 -34
  1259. data/src/core/lib/promise/loop.h +16 -12
  1260. data/src/core/lib/promise/map.h +26 -9
  1261. data/src/core/lib/promise/observable.h +181 -0
  1262. data/src/core/lib/promise/party.cc +297 -147
  1263. data/src/core/lib/promise/party.h +139 -361
  1264. data/src/core/lib/promise/pipe.h +21 -44
  1265. data/src/core/lib/promise/poll.h +102 -38
  1266. data/src/core/lib/promise/prioritized_race.h +2 -2
  1267. data/src/core/lib/promise/promise.h +14 -8
  1268. data/src/core/lib/promise/race.h +12 -7
  1269. data/src/core/lib/promise/seq.h +55 -39
  1270. data/src/core/lib/promise/sleep.cc +3 -3
  1271. data/src/core/lib/promise/sleep.h +4 -5
  1272. data/src/core/lib/promise/status_flag.h +148 -49
  1273. data/src/core/lib/promise/try_join.h +37 -21
  1274. data/src/core/lib/promise/try_seq.h +86 -49
  1275. data/src/core/lib/resource_quota/api.cc +4 -6
  1276. data/src/core/lib/resource_quota/api.h +1 -2
  1277. data/src/core/lib/resource_quota/arena.cc +64 -86
  1278. data/src/core/lib/resource_quota/arena.h +143 -215
  1279. data/src/core/lib/resource_quota/connection_quota.cc +2 -3
  1280. data/src/core/lib/resource_quota/connection_quota.h +5 -6
  1281. data/src/core/lib/resource_quota/memory_quota.cc +28 -40
  1282. data/src/core/lib/resource_quota/memory_quota.h +20 -18
  1283. data/src/core/lib/resource_quota/periodic_update.cc +4 -4
  1284. data/src/core/lib/resource_quota/periodic_update.h +2 -4
  1285. data/src/core/lib/resource_quota/resource_quota.h +8 -9
  1286. data/src/core/lib/resource_quota/thread_quota.cc +2 -3
  1287. data/src/core/lib/resource_quota/thread_quota.h +5 -6
  1288. data/src/core/lib/security/authorization/audit_logging.cc +5 -7
  1289. data/src/core/lib/security/authorization/audit_logging.h +5 -6
  1290. data/src/core/lib/security/authorization/authorization_engine.h +3 -3
  1291. data/src/core/lib/security/authorization/authorization_policy_provider.h +4 -5
  1292. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +2 -2
  1293. data/src/core/lib/security/authorization/evaluate_args.cc +10 -14
  1294. data/src/core/lib/security/authorization/evaluate_args.h +3 -4
  1295. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +2 -4
  1296. data/src/core/lib/security/authorization/grpc_authorization_engine.h +2 -3
  1297. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +22 -30
  1298. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +5 -3
  1299. data/src/core/lib/security/authorization/matchers.cc +5 -7
  1300. data/src/core/lib/security/authorization/matchers.h +2 -4
  1301. data/src/core/lib/security/authorization/rbac_policy.cc +2 -2
  1302. data/src/core/lib/security/authorization/rbac_policy.h +3 -5
  1303. data/src/core/lib/security/authorization/stdout_logger.cc +4 -5
  1304. data/src/core/lib/security/authorization/stdout_logger.h +4 -4
  1305. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +8 -9
  1306. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +4 -5
  1307. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +2 -3
  1308. data/src/core/lib/security/context/security_context.cc +48 -48
  1309. data/src/core/lib/security/context/security_context.h +39 -18
  1310. data/src/core/lib/security/credentials/alts/alts_credentials.cc +5 -5
  1311. data/src/core/lib/security/credentials/alts/alts_credentials.h +9 -5
  1312. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +4 -4
  1313. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +1 -2
  1314. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +3 -5
  1315. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +3 -5
  1316. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +4 -5
  1317. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +3 -3
  1318. data/src/core/lib/security/credentials/call_creds_util.cc +8 -7
  1319. data/src/core/lib/security/credentials/call_creds_util.h +2 -2
  1320. data/src/core/lib/security/credentials/channel_creds_registry.h +7 -8
  1321. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +14 -13
  1322. data/src/core/lib/security/credentials/composite/composite_credentials.cc +10 -14
  1323. data/src/core/lib/security/credentials/composite/composite_credentials.h +11 -10
  1324. data/src/core/lib/security/credentials/credentials.cc +18 -19
  1325. data/src/core/lib/security/credentials/credentials.h +12 -14
  1326. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +335 -339
  1327. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +60 -48
  1328. data/src/core/lib/security/credentials/external/aws_request_signer.cc +4 -5
  1329. data/src/core/lib/security/credentials/external/aws_request_signer.h +3 -3
  1330. data/src/core/lib/security/credentials/external/external_account_credentials.cc +408 -374
  1331. data/src/core/lib/security/credentials/external/external_account_credentials.h +128 -60
  1332. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +90 -52
  1333. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +32 -11
  1334. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +102 -129
  1335. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +22 -24
  1336. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -4
  1337. data/src/core/lib/security/credentials/fake/fake_credentials.h +8 -7
  1338. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +195 -0
  1339. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.h +90 -0
  1340. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +6 -7
  1341. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +55 -73
  1342. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +8 -6
  1343. data/src/core/lib/security/credentials/iam/iam_credentials.cc +5 -10
  1344. data/src/core/lib/security/credentials/iam/iam_credentials.h +8 -7
  1345. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +2 -2
  1346. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +2 -2
  1347. data/src/core/lib/security/credentials/jwt/json_token.cc +25 -29
  1348. data/src/core/lib/security/credentials/jwt/json_token.h +2 -3
  1349. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +22 -29
  1350. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +10 -10
  1351. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +67 -74
  1352. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +3 -4
  1353. data/src/core/lib/security/credentials/local/local_credentials.cc +2 -2
  1354. data/src/core/lib/security/credentials/local/local_credentials.h +3 -3
  1355. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +195 -296
  1356. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +50 -73
  1357. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +20 -33
  1358. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +12 -14
  1359. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +35 -47
  1360. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +5 -8
  1361. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +3 -4
  1362. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +4 -5
  1363. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +1 -3
  1364. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +102 -42
  1365. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +14 -13
  1366. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +6 -10
  1367. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +9 -11
  1368. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +10 -13
  1369. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +1 -1
  1370. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +6 -10
  1371. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.h +8 -10
  1372. data/src/core/lib/security/credentials/tls/tls_credentials.cc +20 -23
  1373. data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -3
  1374. data/src/core/lib/security/credentials/tls/tls_utils.cc +5 -6
  1375. data/src/core/lib/security/credentials/tls/tls_utils.h +3 -3
  1376. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.cc +298 -0
  1377. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.h +175 -0
  1378. data/src/core/lib/security/credentials/xds/xds_credentials.cc +15 -13
  1379. data/src/core/lib/security/credentials/xds/xds_credentials.h +7 -9
  1380. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +22 -27
  1381. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +1 -1
  1382. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +24 -24
  1383. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +1 -1
  1384. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +4 -7
  1385. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +5 -6
  1386. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +9 -11
  1387. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +4 -6
  1388. data/src/core/lib/security/security_connector/local/local_security_connector.cc +25 -25
  1389. data/src/core/lib/security/security_connector/local/local_security_connector.h +1 -1
  1390. data/src/core/lib/security/security_connector/security_connector.cc +6 -11
  1391. data/src/core/lib/security/security_connector/security_connector.h +8 -11
  1392. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +23 -27
  1393. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +2 -3
  1394. data/src/core/lib/security/security_connector/ssl_utils.cc +33 -34
  1395. data/src/core/lib/security/security_connector/ssl_utils.h +6 -8
  1396. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +37 -50
  1397. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +7 -8
  1398. data/src/core/lib/security/transport/auth_filters.h +7 -3
  1399. data/src/core/lib/security/transport/client_auth_filter.cc +16 -25
  1400. data/src/core/lib/security/transport/server_auth_filter.cc +20 -31
  1401. data/src/core/lib/security/util/json_util.cc +4 -5
  1402. data/src/core/lib/security/util/json_util.h +1 -1
  1403. data/src/core/lib/slice/percent_encoding.cc +2 -5
  1404. data/src/core/lib/slice/slice.cc +4 -7
  1405. data/src/core/lib/slice/slice.h +6 -9
  1406. data/src/core/lib/slice/slice_buffer.cc +4 -7
  1407. data/src/core/lib/slice/slice_buffer.h +3 -4
  1408. data/src/core/lib/slice/slice_internal.h +3 -6
  1409. data/src/core/lib/slice/slice_refcount.h +8 -15
  1410. data/src/core/lib/slice/slice_string_helpers.cc +1 -1
  1411. data/src/core/lib/slice/slice_string_helpers.h +1 -2
  1412. data/src/core/lib/surface/byte_buffer.cc +1 -2
  1413. data/src/core/lib/surface/byte_buffer_reader.cc +3 -6
  1414. data/src/core/lib/surface/call.cc +161 -3826
  1415. data/src/core/lib/surface/call.h +63 -157
  1416. data/src/core/lib/surface/call_details.cc +4 -3
  1417. data/src/core/lib/surface/call_log_batch.cc +8 -11
  1418. data/src/core/lib/surface/call_test_only.h +1 -2
  1419. data/src/core/lib/surface/call_utils.cc +231 -0
  1420. data/src/core/lib/surface/call_utils.h +482 -0
  1421. data/src/core/lib/surface/channel.cc +41 -40
  1422. data/src/core/lib/surface/channel.h +21 -19
  1423. data/src/core/lib/surface/channel_create.cc +27 -12
  1424. data/src/core/lib/surface/channel_create.h +5 -5
  1425. data/src/core/lib/surface/channel_init.cc +269 -266
  1426. data/src/core/lib/surface/channel_init.h +172 -118
  1427. data/src/core/lib/surface/client_call.cc +427 -0
  1428. data/src/core/lib/surface/client_call.h +179 -0
  1429. data/src/core/lib/surface/completion_queue.cc +110 -106
  1430. data/src/core/lib/surface/completion_queue.h +3 -12
  1431. data/src/core/lib/surface/completion_queue_factory.cc +1 -3
  1432. data/src/core/lib/surface/event_string.cc +2 -2
  1433. data/src/core/lib/surface/event_string.h +2 -2
  1434. data/src/core/lib/surface/filter_stack_call.cc +1156 -0
  1435. data/src/core/lib/surface/filter_stack_call.h +366 -0
  1436. data/src/core/lib/surface/init.cc +55 -18
  1437. data/src/core/lib/surface/init.h +5 -0
  1438. data/src/core/lib/surface/lame_client.cc +11 -14
  1439. data/src/core/lib/surface/lame_client.h +6 -5
  1440. data/src/core/lib/surface/legacy_channel.cc +60 -46
  1441. data/src/core/lib/surface/legacy_channel.h +15 -25
  1442. data/src/core/lib/surface/metadata_array.cc +5 -5
  1443. data/src/core/lib/surface/server_call.cc +221 -0
  1444. data/src/core/lib/surface/server_call.h +168 -0
  1445. data/src/core/lib/surface/validate_metadata.cc +3 -4
  1446. data/src/core/lib/surface/validate_metadata.h +2 -5
  1447. data/src/core/lib/surface/version.cc +2 -2
  1448. data/src/core/lib/transport/bdp_estimator.cc +11 -19
  1449. data/src/core/lib/transport/bdp_estimator.h +10 -16
  1450. data/src/core/lib/transport/call_arena_allocator.cc +4 -18
  1451. data/src/core/lib/transport/call_arena_allocator.h +30 -12
  1452. data/src/core/lib/transport/call_destination.h +76 -0
  1453. data/src/core/lib/transport/call_filters.cc +61 -405
  1454. data/src/core/lib/transport/call_filters.h +802 -752
  1455. data/src/core/lib/transport/call_final_info.cc +2 -2
  1456. data/src/core/lib/transport/call_final_info.h +2 -2
  1457. data/src/core/lib/transport/call_spine.cc +98 -73
  1458. data/src/core/lib/transport/call_spine.h +183 -380
  1459. data/src/core/lib/transport/call_state.cc +39 -0
  1460. data/src/core/lib/transport/call_state.h +1061 -0
  1461. data/src/core/lib/transport/connectivity_state.cc +37 -45
  1462. data/src/core/lib/transport/connectivity_state.h +5 -8
  1463. data/src/core/lib/transport/error_utils.cc +3 -4
  1464. data/src/core/lib/transport/error_utils.h +4 -5
  1465. data/src/core/lib/transport/interception_chain.cc +147 -0
  1466. data/src/core/lib/transport/interception_chain.h +253 -0
  1467. data/src/core/lib/transport/message.cc +2 -2
  1468. data/src/core/lib/transport/message.h +5 -0
  1469. data/src/core/lib/transport/metadata.cc +27 -3
  1470. data/src/core/lib/transport/metadata.h +37 -2
  1471. data/src/core/lib/transport/metadata_batch.cc +1 -3
  1472. data/src/core/lib/transport/metadata_batch.h +64 -12
  1473. data/src/core/lib/transport/metadata_compression_traits.h +1 -2
  1474. data/src/core/lib/transport/metadata_info.h +1 -1
  1475. data/src/core/lib/transport/parsed_metadata.h +3 -5
  1476. data/src/core/lib/transport/simple_slice_based_metadata.h +1 -2
  1477. data/src/core/lib/transport/status_conversion.h +1 -1
  1478. data/src/core/lib/transport/timeout_encoding.cc +3 -4
  1479. data/src/core/lib/transport/timeout_encoding.h +2 -4
  1480. data/src/core/lib/transport/transport.cc +7 -12
  1481. data/src/core/lib/transport/transport.h +59 -56
  1482. data/src/core/lib/transport/transport_op_string.cc +4 -6
  1483. data/src/core/load_balancing/address_filtering.cc +2 -4
  1484. data/src/core/load_balancing/address_filtering.h +4 -5
  1485. data/src/core/load_balancing/backend_metric_data.h +2 -2
  1486. data/src/core/load_balancing/backend_metric_parser.cc +1 -2
  1487. data/src/core/load_balancing/backend_metric_parser.h +1 -3
  1488. data/src/core/load_balancing/child_policy_handler.cc +36 -40
  1489. data/src/core/load_balancing/child_policy_handler.h +4 -5
  1490. data/src/core/load_balancing/delegating_helper.h +6 -7
  1491. data/src/core/load_balancing/endpoint_list.cc +11 -13
  1492. data/src/core/load_balancing/endpoint_list.h +7 -9
  1493. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +12 -6
  1494. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +5 -2
  1495. data/src/core/load_balancing/grpclb/grpclb.cc +153 -187
  1496. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +2 -3
  1497. data/src/core/load_balancing/grpclb/grpclb_client_stats.cc +2 -3
  1498. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +5 -7
  1499. data/src/core/load_balancing/grpclb/load_balancer_api.cc +7 -10
  1500. data/src/core/load_balancing/grpclb/load_balancer_api.h +4 -6
  1501. data/src/core/load_balancing/health_check_client.cc +60 -80
  1502. data/src/core/load_balancing/health_check_client.h +3 -3
  1503. data/src/core/load_balancing/health_check_client_internal.h +8 -9
  1504. data/src/core/load_balancing/lb_policy.cc +5 -8
  1505. data/src/core/load_balancing/lb_policy.h +72 -38
  1506. data/src/core/load_balancing/lb_policy_factory.h +5 -6
  1507. data/src/core/load_balancing/lb_policy_registry.cc +5 -7
  1508. data/src/core/load_balancing/lb_policy_registry.h +5 -6
  1509. data/src/core/load_balancing/oob_backend_metric.cc +19 -25
  1510. data/src/core/load_balancing/oob_backend_metric.h +3 -3
  1511. data/src/core/load_balancing/oob_backend_metric_internal.h +8 -9
  1512. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +139 -184
  1513. data/src/core/load_balancing/outlier_detection/outlier_detection.h +6 -8
  1514. data/src/core/load_balancing/pick_first/pick_first.cc +219 -303
  1515. data/src/core/load_balancing/priority/priority.cc +93 -137
  1516. data/src/core/load_balancing/ring_hash/ring_hash.cc +52 -76
  1517. data/src/core/load_balancing/ring_hash/ring_hash.h +6 -7
  1518. data/src/core/load_balancing/rls/rls.cc +340 -345
  1519. data/src/core/load_balancing/round_robin/round_robin.cc +56 -83
  1520. data/src/core/load_balancing/subchannel_interface.h +17 -6
  1521. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +2 -3
  1522. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.h +1 -2
  1523. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +138 -155
  1524. data/src/core/load_balancing/weighted_target/weighted_target.cc +71 -107
  1525. data/src/core/load_balancing/xds/cds.cc +53 -69
  1526. data/src/core/load_balancing/xds/xds_cluster_impl.cc +178 -155
  1527. data/src/core/load_balancing/xds/xds_cluster_manager.cc +52 -84
  1528. data/src/core/load_balancing/xds/xds_override_host.cc +117 -179
  1529. data/src/core/load_balancing/xds/xds_override_host.h +6 -7
  1530. data/src/core/load_balancing/xds/xds_wrr_locality.cc +38 -48
  1531. data/src/core/plugin_registry/grpc_plugin_registry.cc +5 -7
  1532. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +5 -0
  1533. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +85 -60
  1534. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +1 -2
  1535. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +4 -6
  1536. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +2 -6
  1537. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +118 -100
  1538. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +166 -151
  1539. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +4 -18
  1540. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  1541. data/src/core/resolver/dns/dns_resolver_plugin.cc +9 -10
  1542. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +52 -59
  1543. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +3 -4
  1544. data/src/core/resolver/dns/event_engine/service_config_helper.cc +8 -10
  1545. data/src/core/resolver/dns/event_engine/service_config_helper.h +2 -2
  1546. data/src/core/resolver/dns/native/dns_resolver.cc +21 -30
  1547. data/src/core/resolver/endpoint_addresses.cc +2 -5
  1548. data/src/core/resolver/endpoint_addresses.h +5 -3
  1549. data/src/core/resolver/fake/fake_resolver.cc +7 -9
  1550. data/src/core/resolver/fake/fake_resolver.h +8 -9
  1551. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +23 -25
  1552. data/src/core/resolver/polling_resolver.cc +39 -55
  1553. data/src/core/resolver/polling_resolver.h +8 -9
  1554. data/src/core/resolver/resolver.cc +2 -6
  1555. data/src/core/resolver/resolver.h +4 -10
  1556. data/src/core/resolver/resolver_factory.h +4 -5
  1557. data/src/core/resolver/resolver_registry.cc +8 -10
  1558. data/src/core/resolver/resolver_registry.h +4 -5
  1559. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +7 -8
  1560. data/src/core/resolver/xds/xds_config.cc +95 -0
  1561. data/src/core/resolver/xds/xds_config.h +108 -0
  1562. data/src/core/resolver/xds/xds_dependency_manager.cc +82 -171
  1563. data/src/core/resolver/xds/xds_dependency_manager.h +6 -71
  1564. data/src/core/resolver/xds/xds_resolver.cc +123 -104
  1565. data/src/core/resolver/xds/xds_resolver_attributes.h +7 -4
  1566. data/src/core/server/server.cc +382 -484
  1567. data/src/core/server/server.h +48 -32
  1568. data/src/core/server/server_call_tracer_filter.cc +20 -19
  1569. data/src/core/server/server_config_selector.h +6 -7
  1570. data/src/core/server/server_config_selector_filter.cc +17 -12
  1571. data/src/core/server/server_interface.h +2 -0
  1572. data/src/core/server/xds_channel_stack_modifier.cc +4 -4
  1573. data/src/core/server/xds_channel_stack_modifier.h +6 -7
  1574. data/src/core/server/xds_server_config_fetcher.cc +63 -73
  1575. data/src/core/service_config/service_config.h +4 -6
  1576. data/src/core/service_config/service_config_call_data.h +21 -20
  1577. data/src/core/service_config/service_config_channel_arg_filter.cc +16 -12
  1578. data/src/core/service_config/service_config_impl.cc +8 -10
  1579. data/src/core/service_config/service_config_impl.h +5 -8
  1580. data/src/core/service_config/service_config_parser.cc +4 -8
  1581. data/src/core/service_config/service_config_parser.h +3 -5
  1582. data/src/core/{lib/channel → telemetry}/call_tracer.cc +56 -34
  1583. data/src/core/{lib/channel → telemetry}/call_tracer.h +51 -14
  1584. data/src/core/{lib/debug → telemetry}/histogram_view.cc +1 -1
  1585. data/src/core/{lib/debug → telemetry}/histogram_view.h +4 -5
  1586. data/src/core/telemetry/metrics.cc +177 -0
  1587. data/src/core/telemetry/metrics.h +565 -0
  1588. data/src/core/{lib/debug → telemetry}/stats.cc +2 -3
  1589. data/src/core/{lib/debug → telemetry}/stats.h +7 -9
  1590. data/src/core/{lib/debug → telemetry}/stats_data.cc +88 -3
  1591. data/src/core/{lib/debug → telemetry}/stats_data.h +73 -8
  1592. data/src/core/{lib/channel → telemetry}/tcp_tracer.h +4 -5
  1593. data/src/core/tsi/alts/crypt/aes_gcm.cc +5 -8
  1594. data/src/core/tsi/alts/crypt/gsec.cc +2 -3
  1595. data/src/core/tsi/alts/crypt/gsec.h +3 -4
  1596. data/src/core/tsi/alts/frame_protector/alts_counter.cc +1 -2
  1597. data/src/core/tsi/alts/frame_protector/alts_counter.h +2 -3
  1598. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +1 -2
  1599. data/src/core/tsi/alts/frame_protector/alts_crypter.h +2 -3
  1600. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +16 -18
  1601. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +1 -2
  1602. data/src/core/tsi/alts/frame_protector/frame_handler.cc +11 -12
  1603. data/src/core/tsi/alts/frame_protector/frame_handler.h +1 -2
  1604. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +41 -46
  1605. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +2 -4
  1606. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +1 -1
  1607. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +55 -57
  1608. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +3 -3
  1609. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +17 -24
  1610. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +1 -2
  1611. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +14 -17
  1612. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +1 -2
  1613. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +11 -12
  1614. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +1 -2
  1615. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +9 -11
  1616. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +3 -5
  1617. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +1 -2
  1618. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +9 -13
  1619. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +1 -2
  1620. data/src/core/tsi/fake_transport_security.cc +27 -32
  1621. data/src/core/tsi/local_transport_security.cc +9 -10
  1622. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +9 -12
  1623. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +8 -10
  1624. data/src/core/tsi/ssl/session_cache/ssl_session.h +4 -5
  1625. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +7 -9
  1626. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +7 -8
  1627. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -4
  1628. data/src/core/tsi/ssl_transport_security.cc +126 -111
  1629. data/src/core/tsi/ssl_transport_security.h +4 -6
  1630. data/src/core/tsi/ssl_transport_security_utils.cc +77 -24
  1631. data/src/core/tsi/ssl_transport_security_utils.h +13 -4
  1632. data/src/core/tsi/ssl_types.h +1 -2
  1633. data/src/core/tsi/transport_security.cc +2 -7
  1634. data/src/core/tsi/transport_security.h +1 -4
  1635. data/src/core/tsi/transport_security_interface.h +1 -6
  1636. data/src/core/{lib/gpr → util}/alloc.cc +2 -6
  1637. data/src/core/{lib/gpr → util}/alloc.h +3 -3
  1638. data/src/core/{lib/gpr → util}/atm.cc +2 -3
  1639. data/src/core/{lib/gprpp → util}/atomic_utils.h +5 -5
  1640. data/src/core/{lib/avl → util}/avl.h +7 -8
  1641. data/src/core/{lib/backoff → util}/backoff.cc +10 -11
  1642. data/src/core/{lib/backoff → util}/backoff.h +8 -11
  1643. data/src/core/{lib/gprpp → util}/bitset.h +6 -7
  1644. data/src/core/{lib/gprpp → util}/chunked_vector.h +6 -8
  1645. data/src/core/{lib/gprpp → util}/construct_destruct.h +8 -7
  1646. data/src/core/{lib/gprpp → util}/cpp_impl_of.h +3 -3
  1647. data/src/core/{lib/gprpp → util}/crash.cc +4 -6
  1648. data/src/core/{lib/gprpp → util}/crash.h +5 -6
  1649. data/src/core/{lib/gprpp → util}/debug_location.h +11 -4
  1650. data/src/core/{lib/gprpp → util}/directory_reader.h +5 -5
  1651. data/src/core/{lib/gprpp → util}/down_cast.h +7 -8
  1652. data/src/core/{lib/gprpp → util}/dual_ref_counted.h +54 -43
  1653. data/src/core/util/dump_args.cc +54 -0
  1654. data/src/core/util/dump_args.h +122 -0
  1655. data/src/core/{lib/gprpp → util}/env.h +5 -5
  1656. data/src/core/{lib/debug → util}/event_log.cc +3 -4
  1657. data/src/core/{lib/debug → util}/event_log.h +7 -9
  1658. data/src/core/{lib/gprpp → util}/examine_stack.cc +1 -1
  1659. data/src/core/{lib/gprpp → util}/examine_stack.h +5 -5
  1660. data/src/core/{lib/gprpp → util}/fork.cc +4 -4
  1661. data/src/core/{lib/gprpp → util}/fork.h +5 -5
  1662. data/src/core/{ext/gcp/metadata_query.cc → util/gcp_metadata_query.cc} +31 -36
  1663. data/src/core/{ext/gcp/metadata_query.h → util/gcp_metadata_query.h} +13 -14
  1664. data/src/core/{lib/iomgr → util}/gethostname.h +3 -3
  1665. data/src/core/{lib/iomgr → util}/gethostname_fallback.cc +1 -1
  1666. data/src/core/{lib/iomgr → util}/gethostname_host_name_max.cc +2 -3
  1667. data/src/core/{lib/iomgr → util}/gethostname_sysconf.cc +2 -3
  1668. data/src/core/util/glob.cc +70 -0
  1669. data/src/core/util/glob.h +29 -0
  1670. data/src/core/{lib/gpr/time.cc → util/gpr_time.cc} +3 -6
  1671. data/src/core/{lib/iomgr → util}/grpc_if_nametoindex.h +4 -5
  1672. data/src/core/{lib/iomgr → util}/grpc_if_nametoindex_posix.cc +4 -6
  1673. data/src/core/{lib/iomgr → util}/grpc_if_nametoindex_unsupported.cc +5 -8
  1674. data/src/core/{lib/gprpp → util}/host_port.cc +2 -4
  1675. data/src/core/{lib/gprpp → util}/host_port.h +5 -5
  1676. data/src/core/{lib/http → util/http_client}/format_request.cc +4 -6
  1677. data/src/core/{lib/http → util/http_client}/format_request.h +4 -4
  1678. data/src/core/{lib/http → util/http_client}/httpcli.cc +43 -62
  1679. data/src/core/{lib/http → util/http_client}/httpcli.h +32 -30
  1680. data/src/core/{lib/http → util/http_client}/httpcli_security_connector.cc +17 -20
  1681. data/src/core/{lib/http → util/http_client}/httpcli_ssl_credentials.h +4 -4
  1682. data/src/core/{lib/http → util/http_client}/parser.cc +7 -11
  1683. data/src/core/{lib/http → util/http_client}/parser.h +5 -8
  1684. data/src/core/{lib/gprpp → util}/if_list.h +3 -3
  1685. data/src/core/{lib/gpr → util}/iphone/cpu.cc +1 -2
  1686. data/src/core/{lib → util}/json/json.h +3 -3
  1687. data/src/core/{lib → util}/json/json_args.h +5 -5
  1688. data/src/core/{lib → util}/json/json_channel_args.h +6 -7
  1689. data/src/core/{lib → util}/json/json_object_loader.cc +4 -4
  1690. data/src/core/{lib → util}/json/json_object_loader.h +11 -12
  1691. data/src/core/{lib → util}/json/json_reader.cc +4 -7
  1692. data/src/core/{lib → util}/json/json_reader.h +6 -7
  1693. data/src/core/{lib → util}/json/json_util.cc +5 -5
  1694. data/src/core/{lib → util}/json/json_util.h +7 -8
  1695. data/src/core/{lib → util}/json/json_writer.cc +2 -4
  1696. data/src/core/{lib → util}/json/json_writer.h +6 -6
  1697. data/src/core/util/latent_see.cc +142 -0
  1698. data/src/core/util/latent_see.h +327 -0
  1699. data/src/core/{lib/gpr → util}/linux/cpu.cc +11 -12
  1700. data/src/core/{lib/gprpp → util}/linux/env.cc +3 -3
  1701. data/src/core/{lib/gprpp → util}/load_file.cc +4 -6
  1702. data/src/core/{lib/gprpp → util}/load_file.h +5 -6
  1703. data/src/core/util/log.cc +127 -0
  1704. data/src/core/util/lru_cache.h +122 -0
  1705. data/src/core/{lib/gprpp → util}/manual_constructor.h +5 -6
  1706. data/src/core/{lib/gprpp → util}/match.h +6 -7
  1707. data/src/core/{lib/matchers → util}/matchers.cc +10 -3
  1708. data/src/core/{lib/matchers → util}/matchers.h +9 -5
  1709. data/src/core/{lib/gprpp → util}/memory.h +6 -6
  1710. data/src/core/{lib/gprpp → util}/mpscq.cc +1 -1
  1711. data/src/core/{lib/gprpp → util}/mpscq.h +6 -8
  1712. data/src/core/{lib/gpr → util}/msys/tmpfile.cc +5 -7
  1713. data/src/core/{lib/gprpp → util}/no_destruct.h +6 -6
  1714. data/src/core/{lib/gprpp → util}/notification.h +6 -7
  1715. data/src/core/{lib/gprpp → util}/orphanable.h +9 -9
  1716. data/src/core/{lib/gprpp → util}/overload.h +5 -5
  1717. data/src/core/{lib/gprpp → util}/packed_table.h +5 -5
  1718. data/src/core/{lib/gprpp → util}/per_cpu.cc +2 -2
  1719. data/src/core/{lib/gprpp → util}/per_cpu.h +5 -6
  1720. data/src/core/{lib/gpr → util}/posix/cpu.cc +6 -7
  1721. data/src/core/{lib/gprpp → util}/posix/directory_reader.cc +4 -4
  1722. data/src/core/{lib/gprpp → util}/posix/env.cc +1 -1
  1723. data/src/core/{lib/gprpp → util}/posix/stat.cc +7 -9
  1724. data/src/core/{lib/gpr → util}/posix/string.cc +2 -3
  1725. data/src/core/{lib/gpr → util}/posix/sync.cc +3 -6
  1726. data/src/core/{lib/gprpp → util}/posix/thd.cc +16 -20
  1727. data/src/core/{lib/gpr → util}/posix/time.cc +5 -7
  1728. data/src/core/{lib/gpr → util}/posix/tmpfile.cc +11 -13
  1729. data/src/core/{lib/backoff → util}/random_early_detection.cc +3 -3
  1730. data/src/core/{lib/backoff → util}/random_early_detection.h +4 -5
  1731. data/src/core/{lib/gprpp → util}/ref_counted.h +39 -32
  1732. data/src/core/{lib/gprpp → util}/ref_counted_ptr.h +6 -8
  1733. data/src/core/{lib/gprpp → util}/ref_counted_string.cc +3 -4
  1734. data/src/core/{lib/gprpp → util}/ref_counted_string.h +6 -8
  1735. data/src/core/util/ring_buffer.h +123 -0
  1736. data/src/core/{lib/gprpp → util}/single_set_ptr.h +10 -9
  1737. data/src/core/{lib/gprpp → util}/sorted_pack.h +6 -6
  1738. data/src/core/{lib/gpr → util}/spinlock.h +5 -7
  1739. data/src/core/{lib/gprpp → util}/stat.h +4 -5
  1740. data/src/core/{lib/gprpp → util}/status_helper.cc +16 -38
  1741. data/src/core/{lib/gprpp → util}/status_helper.h +8 -38
  1742. data/src/core/{lib/gprpp → util}/strerror.cc +2 -3
  1743. data/src/core/{lib/gprpp → util}/strerror.h +5 -5
  1744. data/src/core/{lib/gpr → util}/string.cc +13 -16
  1745. data/src/core/{lib/gpr → util}/string.h +4 -6
  1746. data/src/core/{lib/gpr → util}/sync.cc +3 -6
  1747. data/src/core/{lib/gprpp → util}/sync.h +7 -8
  1748. data/src/core/{lib/gpr → util}/sync_abseil.cc +5 -8
  1749. data/src/core/{lib/gprpp → util}/table.h +56 -22
  1750. data/src/core/{lib/gprpp → util}/tchar.cc +1 -1
  1751. data/src/core/{lib/gprpp → util}/tchar.h +3 -3
  1752. data/src/core/{lib/gprpp → util}/thd.h +5 -7
  1753. data/src/core/{lib/gprpp → util}/time.cc +8 -10
  1754. data/src/core/{lib/gprpp → util}/time.h +28 -27
  1755. data/src/core/{lib/gprpp → util}/time_averaged_stats.cc +1 -1
  1756. data/src/core/{lib/gprpp → util}/time_averaged_stats.h +3 -3
  1757. data/src/core/{lib/gpr → util}/time_precise.cc +7 -7
  1758. data/src/core/{lib/gpr → util}/time_precise.h +3 -4
  1759. data/src/core/{lib/gprpp → util}/time_util.cc +3 -5
  1760. data/src/core/{lib/gprpp → util}/time_util.h +5 -5
  1761. data/src/core/{lib/gpr → util}/tmpfile.h +3 -4
  1762. data/src/core/{lib/gprpp → util}/type_list.h +3 -3
  1763. data/src/core/util/unique_ptr_with_bitset.h +86 -0
  1764. data/src/core/{lib/gprpp → util}/unique_type_name.h +34 -15
  1765. data/src/core/{xds/grpc → util}/upb_utils.h +3 -5
  1766. data/src/core/{lib/uri/uri_parser.cc → util/uri.cc} +2 -4
  1767. data/src/core/{lib/uri/uri_parser.h → util/uri.h} +5 -5
  1768. data/src/core/{lib/gpr → util}/useful.h +23 -52
  1769. data/src/core/{lib/gprpp → util}/uuid_v4.cc +3 -3
  1770. data/src/core/{lib/gprpp → util}/uuid_v4.h +4 -5
  1771. data/src/core/{lib/gprpp → util}/validation_errors.cc +12 -4
  1772. data/src/core/{lib/gprpp → util}/validation_errors.h +15 -5
  1773. data/src/core/{lib/gpr → util}/windows/cpu.cc +1 -2
  1774. data/src/core/{lib/gprpp → util}/windows/directory_reader.cc +1 -3
  1775. data/src/core/{lib/gprpp → util}/windows/env.cc +2 -2
  1776. data/src/core/{lib/gprpp → util}/windows/stat.cc +6 -8
  1777. data/src/core/{lib/gpr → util}/windows/string.cc +3 -4
  1778. data/src/core/{lib/gpr → util}/windows/string_util.cc +6 -8
  1779. data/src/core/{lib/gpr → util}/windows/sync.cc +2 -4
  1780. data/src/core/{lib/gprpp → util}/windows/thd.cc +8 -10
  1781. data/src/core/{lib/gpr → util}/windows/time.cc +3 -6
  1782. data/src/core/{lib/gpr → util}/windows/tmpfile.cc +5 -7
  1783. data/src/core/{lib/gprpp → util}/work_serializer.cc +75 -95
  1784. data/src/core/{lib/gprpp → util}/work_serializer.h +8 -9
  1785. data/src/core/{lib/gprpp → util}/xxhash_inline.h +3 -3
  1786. data/src/core/xds/grpc/certificate_provider_store.cc +4 -5
  1787. data/src/core/xds/grpc/certificate_provider_store.h +12 -13
  1788. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +6 -7
  1789. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +9 -10
  1790. data/src/core/xds/grpc/xds_audit_logger_registry.cc +5 -5
  1791. data/src/core/xds/grpc/xds_audit_logger_registry.h +4 -5
  1792. data/src/core/xds/grpc/xds_bootstrap_grpc.cc +8 -166
  1793. data/src/core/xds/grpc/xds_bootstrap_grpc.h +9 -39
  1794. data/src/core/xds/grpc/xds_certificate_provider.cc +4 -5
  1795. data/src/core/xds/grpc/xds_certificate_provider.h +12 -11
  1796. data/src/core/xds/grpc/xds_client_grpc.cc +98 -76
  1797. data/src/core/xds/grpc/xds_client_grpc.h +16 -10
  1798. data/src/core/xds/grpc/xds_cluster.cc +12 -737
  1799. data/src/core/xds/grpc/xds_cluster.h +36 -45
  1800. data/src/core/xds/grpc/xds_cluster_parser.cc +772 -0
  1801. data/src/core/xds/grpc/xds_cluster_parser.h +61 -0
  1802. data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +6 -9
  1803. data/src/core/xds/grpc/xds_cluster_specifier_plugin.h +5 -6
  1804. data/src/core/xds/grpc/xds_common_types.cc +33 -438
  1805. data/src/core/xds/grpc/xds_common_types.h +10 -28
  1806. data/src/core/xds/grpc/xds_common_types_parser.cc +503 -0
  1807. data/src/core/xds/grpc/xds_common_types_parser.h +76 -0
  1808. data/src/core/xds/grpc/xds_endpoint.cc +0 -420
  1809. data/src/core/xds/grpc/xds_endpoint.h +7 -29
  1810. data/src/core/xds/grpc/xds_endpoint_parser.cc +444 -0
  1811. data/src/core/xds/grpc/xds_endpoint_parser.h +47 -0
  1812. data/src/core/xds/grpc/xds_health_status.cc +0 -2
  1813. data/src/core/xds/grpc/xds_health_status.h +0 -3
  1814. data/src/core/xds/grpc/xds_http_fault_filter.cc +28 -16
  1815. data/src/core/xds/grpc/xds_http_fault_filter.h +11 -7
  1816. data/src/core/xds/grpc/{xds_http_filters.h → xds_http_filter.h} +21 -69
  1817. data/src/core/xds/grpc/{xds_http_filters.cc → xds_http_filter_registry.cc} +11 -5
  1818. data/src/core/xds/grpc/xds_http_filter_registry.h +104 -0
  1819. data/src/core/xds/grpc/xds_http_gcp_authn_filter.cc +141 -0
  1820. data/src/core/xds/grpc/xds_http_gcp_authn_filter.h +60 -0
  1821. data/src/core/xds/grpc/xds_http_rbac_filter.cc +64 -49
  1822. data/src/core/xds/grpc/xds_http_rbac_filter.h +11 -7
  1823. data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +24 -11
  1824. data/src/core/xds/grpc/xds_http_stateful_session_filter.h +11 -7
  1825. data/src/core/xds/grpc/xds_lb_policy_registry.cc +22 -27
  1826. data/src/core/xds/grpc/xds_lb_policy_registry.h +4 -5
  1827. data/src/core/xds/grpc/xds_listener.cc +19 -986
  1828. data/src/core/xds/grpc/xds_listener.h +2 -35
  1829. data/src/core/xds/grpc/xds_listener_parser.cc +993 -0
  1830. data/src/core/xds/grpc/xds_listener_parser.h +59 -0
  1831. data/src/core/xds/grpc/xds_metadata.cc +62 -0
  1832. data/src/core/xds/grpc/xds_metadata.h +150 -0
  1833. data/src/core/xds/grpc/xds_metadata_parser.cc +184 -0
  1834. data/src/core/xds/grpc/xds_metadata_parser.h +35 -0
  1835. data/src/core/xds/grpc/xds_route_config.cc +2 -919
  1836. data/src/core/xds/grpc/xds_route_config.h +8 -41
  1837. data/src/core/xds/grpc/xds_route_config_parser.cc +962 -0
  1838. data/src/core/xds/grpc/xds_route_config_parser.h +77 -0
  1839. data/src/core/xds/grpc/xds_routing.cc +60 -27
  1840. data/src/core/xds/grpc/xds_routing.h +12 -6
  1841. data/src/core/xds/grpc/xds_server_grpc.cc +160 -0
  1842. data/src/core/xds/grpc/xds_server_grpc.h +63 -0
  1843. data/src/core/xds/grpc/xds_transport_grpc.cc +98 -55
  1844. data/src/core/xds/grpc/xds_transport_grpc.h +34 -23
  1845. data/src/core/xds/xds_client/lrs_client.cc +1292 -0
  1846. data/src/core/xds/xds_client/lrs_client.h +394 -0
  1847. data/src/core/xds/xds_client/xds_api.cc +38 -256
  1848. data/src/core/xds/xds_client/xds_api.h +13 -36
  1849. data/src/core/xds/xds_client/xds_backend_metric_propagation.cc +63 -0
  1850. data/src/core/xds/xds_client/xds_backend_metric_propagation.h +59 -0
  1851. data/src/core/xds/xds_client/xds_bootstrap.cc +3 -4
  1852. data/src/core/xds/xds_client/xds_bootstrap.h +3 -3
  1853. data/src/core/xds/xds_client/xds_client.cc +175 -793
  1854. data/src/core/xds/xds_client/xds_client.h +33 -89
  1855. data/src/core/xds/xds_client/xds_locality.h +102 -0
  1856. data/src/core/xds/xds_client/xds_metrics.h +2 -2
  1857. data/src/core/xds/xds_client/xds_resource_type.h +4 -5
  1858. data/src/core/xds/xds_client/xds_resource_type_impl.h +3 -4
  1859. data/src/core/xds/xds_client/xds_transport.h +29 -14
  1860. data/src/ruby/bin/math_pb.rb +1 -22
  1861. data/src/ruby/ext/grpc/extconf.rb +1 -1
  1862. data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -3
  1863. data/src/ruby/ext/grpc/rb_call.c +15 -8
  1864. data/src/ruby/ext/grpc/rb_call_credentials.c +39 -33
  1865. data/src/ruby/ext/grpc/rb_channel.c +42 -37
  1866. data/src/ruby/ext/grpc/rb_channel_args.c +4 -4
  1867. data/src/ruby/ext/grpc/rb_channel_credentials.c +5 -6
  1868. data/src/ruby/ext/grpc/rb_channel_credentials.h +1 -2
  1869. data/src/ruby/ext/grpc/rb_completion_queue.c +18 -36
  1870. data/src/ruby/ext/grpc/rb_completion_queue.h +7 -1
  1871. data/src/ruby/ext/grpc/rb_compression_options.c +9 -10
  1872. data/src/ruby/ext/grpc/rb_event_thread.c +9 -9
  1873. data/src/ruby/ext/grpc/rb_grpc.c +16 -16
  1874. data/src/ruby/ext/grpc/rb_grpc.h +7 -0
  1875. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +6 -14
  1876. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +9 -21
  1877. data/src/ruby/ext/grpc/rb_server.c +47 -28
  1878. data/src/ruby/ext/grpc/rb_server_credentials.c +3 -3
  1879. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -2
  1880. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +5 -6
  1881. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +1 -2
  1882. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +4 -4
  1883. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +1 -2
  1884. data/src/ruby/lib/grpc/generic/active_call.rb +8 -5
  1885. data/src/ruby/lib/grpc/logconfig.rb +13 -0
  1886. data/src/ruby/lib/grpc/version.rb +1 -1
  1887. data/src/ruby/pb/grpc/health/v1/health_pb.rb +1 -22
  1888. data/src/ruby/pb/grpc/testing/duplicate/echo_duplicate_services_pb.rb +5 -5
  1889. data/src/ruby/pb/grpc/testing/metrics_pb.rb +10 -19
  1890. data/src/ruby/pb/grpc/testing/metrics_services_pb.rb +5 -5
  1891. data/src/ruby/pb/src/proto/grpc/testing/empty_pb.rb +1 -22
  1892. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +1 -22
  1893. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +1 -22
  1894. data/src/ruby/spec/call_spec.rb +53 -40
  1895. data/src/ruby/spec/channel_spec.rb +4 -2
  1896. data/src/ruby/spec/client_server_spec.rb +148 -507
  1897. data/src/ruby/spec/generic/active_call_spec.rb +64 -86
  1898. data/src/ruby/spec/generic/client_stub_spec.rb +20 -20
  1899. data/src/ruby/spec/logconfig_spec.rb +30 -0
  1900. data/src/ruby/spec/support/services.rb +3 -0
  1901. data/third_party/abseil-cpp/absl/algorithm/container.h +57 -18
  1902. data/third_party/abseil-cpp/absl/base/attributes.h +84 -0
  1903. data/third_party/abseil-cpp/absl/base/config.h +32 -51
  1904. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +0 -16
  1905. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +3 -1
  1906. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +13 -3
  1907. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -12
  1908. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +4 -4
  1909. data/third_party/abseil-cpp/absl/base/macros.h +48 -0
  1910. data/third_party/abseil-cpp/absl/base/no_destructor.h +35 -40
  1911. data/third_party/abseil-cpp/absl/base/nullability.h +33 -7
  1912. data/third_party/abseil-cpp/absl/base/optimization.h +11 -0
  1913. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  1914. data/third_party/abseil-cpp/absl/base/prefetch.h +1 -1
  1915. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +68 -12
  1916. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +60 -6
  1917. data/third_party/abseil-cpp/absl/container/hash_container_defaults.h +45 -0
  1918. data/third_party/abseil-cpp/absl/container/inlined_vector.h +13 -0
  1919. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +20 -11
  1920. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +15 -16
  1921. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +34 -1
  1922. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +68 -1
  1923. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +50 -0
  1924. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +22 -7
  1925. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +26 -8
  1926. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +39 -35
  1927. data/third_party/abseil-cpp/absl/container/internal/layout.h +190 -74
  1928. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +8 -6
  1929. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +334 -71
  1930. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1299 -458
  1931. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +19 -17
  1932. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.cc +4 -3
  1933. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +2 -1
  1934. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +12 -8
  1935. data/third_party/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +1 -1
  1936. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +11 -7
  1937. data/third_party/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +18 -17
  1938. data/third_party/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence.h +126 -0
  1939. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +258 -0
  1940. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +55 -0
  1941. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1057 -86
  1942. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +3 -0
  1943. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.cc +925 -0
  1944. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.h +42 -0
  1945. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +43 -16
  1946. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +8 -7
  1947. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +10 -7
  1948. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.cc +70 -0
  1949. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.h +47 -0
  1950. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +11 -0
  1951. data/third_party/abseil-cpp/absl/flags/flag.h +2 -0
  1952. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +117 -30
  1953. data/third_party/abseil-cpp/absl/flags/internal/flag.h +192 -30
  1954. data/third_party/abseil-cpp/absl/flags/reflection.cc +10 -0
  1955. data/third_party/abseil-cpp/absl/functional/any_invocable.h +13 -3
  1956. data/third_party/abseil-cpp/absl/functional/bind_front.h +3 -2
  1957. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +7 -7
  1958. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +9 -9
  1959. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +1 -1
  1960. data/third_party/abseil-cpp/absl/hash/internal/hash.h +13 -3
  1961. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +60 -28
  1962. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +4 -0
  1963. data/third_party/abseil-cpp/absl/log/absl_vlog_is_on.h +3 -3
  1964. data/third_party/abseil-cpp/absl/log/globals.h +28 -15
  1965. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +20 -0
  1966. data/third_party/abseil-cpp/absl/log/internal/check_op.h +63 -21
  1967. data/third_party/abseil-cpp/absl/log/internal/conditions.h +2 -2
  1968. data/third_party/abseil-cpp/absl/log/internal/log_impl.h +23 -23
  1969. data/third_party/abseil-cpp/absl/log/internal/log_message.cc +104 -47
  1970. data/third_party/abseil-cpp/absl/log/internal/log_message.h +23 -4
  1971. data/third_party/abseil-cpp/absl/log/internal/nullstream.h +1 -10
  1972. data/third_party/abseil-cpp/absl/log/internal/strip.h +36 -0
  1973. data/third_party/abseil-cpp/absl/log/log.h +5 -1
  1974. data/third_party/abseil-cpp/absl/log/log_sink.h +11 -4
  1975. data/third_party/abseil-cpp/absl/log/vlog_is_on.h +3 -3
  1976. data/third_party/abseil-cpp/absl/meta/type_traits.h +138 -42
  1977. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -3
  1978. data/third_party/abseil-cpp/absl/numeric/int128.h +35 -5
  1979. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +14 -0
  1980. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +18 -0
  1981. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +6 -2
  1982. data/third_party/abseil-cpp/absl/random/beta_distribution.h +8 -8
  1983. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +9 -7
  1984. data/third_party/abseil-cpp/absl/random/distributions.h +11 -11
  1985. data/third_party/abseil-cpp/absl/random/seed_sequences.h +2 -0
  1986. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +61 -2
  1987. data/third_party/abseil-cpp/absl/status/status.cc +0 -4
  1988. data/third_party/abseil-cpp/absl/status/status.h +4 -4
  1989. data/third_party/abseil-cpp/absl/status/statusor.h +108 -142
  1990. data/third_party/abseil-cpp/absl/strings/ascii.cc +32 -71
  1991. data/third_party/abseil-cpp/absl/strings/cord.cc +20 -15
  1992. data/third_party/abseil-cpp/absl/strings/cord.h +68 -7
  1993. data/third_party/abseil-cpp/absl/strings/escaping.cc +96 -21
  1994. data/third_party/abseil-cpp/absl/strings/escaping.h +25 -8
  1995. data/third_party/abseil-cpp/absl/strings/has_absl_stringify.h +1 -0
  1996. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +10 -0
  1997. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +29 -9
  1998. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +2 -2
  1999. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.cc +19 -13
  2000. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.h +23 -13
  2001. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +24 -24
  2002. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +12 -7
  2003. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.h +9 -4
  2004. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +5 -2
  2005. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +23 -2
  2006. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +5 -1
  2007. data/third_party/abseil-cpp/absl/strings/numbers.cc +107 -333
  2008. data/third_party/abseil-cpp/absl/strings/numbers.h +12 -151
  2009. data/third_party/abseil-cpp/absl/strings/str_cat.cc +49 -142
  2010. data/third_party/abseil-cpp/absl/strings/str_cat.h +70 -85
  2011. data/third_party/abseil-cpp/absl/strings/str_format.h +1 -1
  2012. data/third_party/abseil-cpp/absl/strings/str_join.h +19 -5
  2013. data/third_party/abseil-cpp/absl/strings/str_split.h +2 -2
  2014. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  2015. data/third_party/abseil-cpp/absl/strings/substitute.cc +4 -0
  2016. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +11 -2
  2017. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +5 -0
  2018. data/third_party/abseil-cpp/absl/synchronization/mutex.h +5 -4
  2019. data/third_party/abseil-cpp/absl/time/civil_time.h +2 -2
  2020. data/third_party/abseil-cpp/absl/time/clock.cc +15 -1
  2021. data/third_party/abseil-cpp/absl/time/duration.cc +58 -53
  2022. data/third_party/abseil-cpp/absl/time/format.cc +2 -1
  2023. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +1 -1
  2024. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -29
  2025. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +3 -3
  2026. data/third_party/abseil-cpp/absl/time/time.h +73 -29
  2027. data/third_party/abseil-cpp/absl/types/compare.h +505 -0
  2028. data/third_party/abseil-cpp/absl/types/internal/optional.h +2 -2
  2029. data/third_party/abseil-cpp/absl/types/internal/variant.h +55 -67
  2030. data/third_party/abseil-cpp/absl/types/optional.h +15 -18
  2031. data/third_party/abseil-cpp/absl/types/span.h +3 -2
  2032. data/third_party/abseil-cpp/absl/types/variant.h +19 -24
  2033. data/third_party/abseil-cpp/absl/utility/utility.h +3 -41
  2034. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +4 -0
  2035. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand/fork_detect.h → bcm_support.h} +51 -6
  2036. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +12 -12
  2037. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +3 -5
  2038. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +7 -0
  2039. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +43 -0
  2040. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +66 -41
  2041. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.c +4 -1
  2042. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.c +71 -37
  2043. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +8 -62
  2044. data/third_party/boringssl-with-bazel/src/crypto/dilithium/dilithium.c +1539 -0
  2045. data/third_party/boringssl-with-bazel/src/crypto/dilithium/internal.h +58 -0
  2046. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +10 -3
  2047. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +0 -2
  2048. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +2 -0
  2049. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +160 -14
  2050. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{aes.c → aes.c.inc} +21 -0
  2051. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +33 -7
  2052. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +84 -80
  2053. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm_interface.h +89 -0
  2054. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{div.c → div.c.inc} +146 -179
  2055. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{exponentiation.c → exponentiation.c.inc} +45 -1
  2056. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +33 -23
  2057. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{random.c → random.c.inc} +6 -8
  2058. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{sqrt.c → sqrt.c.inc} +1 -1
  2059. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{e_aes.c → e_aes.c.inc} +9 -8
  2060. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{ec_key.c → ec_key.c.inc} +11 -7
  2061. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256-nistz.c → p256-nistz.c.inc} +104 -7
  2062. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.h +65 -8
  2063. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/{ecdsa.c → ecdsa.c.inc} +52 -107
  2064. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +28 -11
  2065. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +3 -6
  2066. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +1 -80
  2067. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/{rand.c → rand.c.inc} +26 -40
  2068. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{padding.c → padding.c.inc} +2 -5
  2069. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{rsa_impl.c → rsa_impl.c.inc} +1 -1
  2070. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/{fips.c → fips.c.inc} +6 -4
  2071. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/{self_check.c → self_check.c.inc} +9 -35
  2072. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +2 -2
  2073. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/{service_indicator.c → service_indicator.c.inc} +2 -2
  2074. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +9 -4
  2075. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/{sha512.c → sha512.c.inc} +6 -0
  2076. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +293 -2
  2077. data/third_party/boringssl-with-bazel/src/crypto/internal.h +98 -24
  2078. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +1 -0
  2079. data/third_party/boringssl-with-bazel/src/crypto/mem.c +7 -3
  2080. data/third_party/boringssl-with-bazel/src/crypto/mldsa/internal.h +73 -0
  2081. data/third_party/boringssl-with-bazel/src/crypto/mldsa/mldsa.c +1687 -0
  2082. data/third_party/boringssl-with-bazel/src/crypto/mlkem/internal.h +90 -0
  2083. data/third_party/boringssl-with-bazel/src/crypto/mlkem/mlkem.cc +1097 -0
  2084. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +4 -1
  2085. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +4 -5
  2086. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +2 -3
  2087. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +1 -1
  2088. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +1 -0
  2089. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +9 -1
  2090. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand → rand_extra}/fork_detect.c +26 -28
  2091. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/getentropy.c +9 -1
  2092. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/ios.c +9 -1
  2093. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +19 -3
  2094. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +26 -23
  2095. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/sysrand_internal.h +37 -0
  2096. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/trusty.c +9 -1
  2097. data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand → rand_extra}/urandom.c +19 -19
  2098. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +8 -1
  2099. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/internal.h +2 -0
  2100. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +0 -4
  2101. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_utl.c +49 -16
  2102. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -10
  2103. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +7 -17
  2104. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +14 -1
  2105. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +8 -6
  2106. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +14 -9
  2107. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +9 -11
  2108. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/dilithium.h +129 -0
  2109. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/kyber.h +10 -0
  2110. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +8 -6
  2111. data/third_party/boringssl-with-bazel/src/include/openssl/mldsa.h +136 -0
  2112. data/third_party/boringssl-with-bazel/src/include/openssl/mlkem.h +246 -0
  2113. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +3 -0
  2114. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +3 -4
  2115. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +2 -2
  2116. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +48 -12
  2117. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +118 -38
  2118. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +0 -23
  2119. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +9 -12
  2120. data/third_party/boringssl-with-bazel/src/ssl/d1_lib.cc +6 -0
  2121. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +10 -5
  2122. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +14 -2
  2123. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +296 -61
  2124. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +24 -16
  2125. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +71 -39
  2126. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +16 -4
  2127. data/third_party/boringssl-with-bazel/src/ssl/internal.h +125 -38
  2128. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +44 -16
  2129. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +21 -1
  2130. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +86 -1
  2131. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +7 -4
  2132. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +98 -3
  2133. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +69 -29
  2134. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +59 -20
  2135. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +7 -1
  2136. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +2 -1
  2137. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +18 -4
  2138. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +96 -34
  2139. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +15 -5
  2140. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +4 -24
  2141. data/third_party/upb/upb/base/string_view.h +1 -1
  2142. data/third_party/upb/upb/json/decode.c +21 -3
  2143. data/third_party/upb/upb/json/encode.c +2 -2
  2144. data/third_party/upb/upb/lex/round_trip.c +10 -0
  2145. data/third_party/upb/upb/mem/arena.c +79 -3
  2146. data/third_party/upb/upb/mem/arena.h +20 -9
  2147. data/third_party/upb/upb/mem/arena.hpp +5 -1
  2148. data/third_party/upb/upb/mem/internal/arena.h +11 -8
  2149. data/third_party/upb/upb/message/accessors.c +6 -7
  2150. data/third_party/upb/upb/message/accessors.h +180 -378
  2151. data/third_party/upb/upb/message/array.c +26 -3
  2152. data/third_party/upb/upb/message/array.h +17 -9
  2153. data/third_party/upb/upb/message/compat.c +5 -5
  2154. data/third_party/upb/upb/message/compat.h +3 -3
  2155. data/third_party/upb/upb/message/copy.c +23 -20
  2156. data/third_party/upb/upb/message/internal/accessors.h +610 -55
  2157. data/third_party/upb/upb/message/internal/array.h +23 -15
  2158. data/third_party/upb/upb/message/internal/compare_unknown.c +289 -0
  2159. data/third_party/upb/upb/message/internal/compare_unknown.h +49 -0
  2160. data/third_party/upb/upb/message/internal/extension.c +12 -12
  2161. data/third_party/upb/upb/message/internal/extension.h +9 -12
  2162. data/third_party/upb/upb/message/internal/map.h +15 -0
  2163. data/third_party/upb/upb/message/internal/map_sorter.h +4 -5
  2164. data/third_party/upb/upb/message/internal/message.c +19 -3
  2165. data/third_party/upb/upb/message/internal/message.h +11 -0
  2166. data/third_party/upb/upb/message/internal/tagged_ptr.h +5 -5
  2167. data/third_party/upb/upb/message/internal/types.h +41 -1
  2168. data/third_party/upb/upb/message/map.c +25 -0
  2169. data/third_party/upb/upb/message/map.h +11 -7
  2170. data/third_party/upb/upb/message/merge.c +38 -0
  2171. data/third_party/upb/upb/message/merge.h +26 -0
  2172. data/third_party/upb/upb/message/message.c +83 -4
  2173. data/third_party/upb/upb/message/message.h +16 -1
  2174. data/third_party/upb/upb/message/tagged_ptr.h +4 -8
  2175. data/third_party/upb/upb/message/value.h +26 -0
  2176. data/third_party/upb/upb/mini_descriptor/build_enum.c +3 -3
  2177. data/third_party/upb/upb/mini_descriptor/build_enum.h +6 -14
  2178. data/third_party/upb/upb/mini_descriptor/decode.c +19 -3
  2179. data/third_party/upb/upb/mini_descriptor/link.c +23 -21
  2180. data/third_party/upb/upb/mini_table/enum.h +2 -4
  2181. data/third_party/upb/upb/mini_table/extension.h +4 -12
  2182. data/third_party/upb/upb/mini_table/extension_registry.c +18 -0
  2183. data/third_party/upb/upb/mini_table/extension_registry.h +17 -0
  2184. data/third_party/upb/upb/mini_table/field.h +12 -38
  2185. data/third_party/upb/upb/mini_table/file.h +6 -19
  2186. data/third_party/upb/upb/mini_table/internal/enum.h +1 -1
  2187. data/third_party/upb/upb/mini_table/internal/extension.h +18 -9
  2188. data/third_party/upb/upb/mini_table/internal/field.h +23 -23
  2189. data/third_party/upb/upb/mini_table/internal/file.h +7 -7
  2190. data/third_party/upb/upb/mini_table/internal/message.c +21 -1
  2191. data/third_party/upb/upb/mini_table/internal/message.h +80 -36
  2192. data/third_party/upb/upb/mini_table/internal/sub.h +9 -4
  2193. data/third_party/upb/upb/mini_table/message.h +23 -22
  2194. data/third_party/upb/upb/mini_table/sub.h +4 -12
  2195. data/third_party/upb/upb/port/def.inc +83 -6
  2196. data/third_party/upb/upb/port/undef.inc +5 -1
  2197. data/third_party/upb/upb/reflection/def.hpp +35 -0
  2198. data/third_party/upb/upb/reflection/def_pool.h +2 -2
  2199. data/third_party/upb/upb/reflection/enum_def.c +5 -1
  2200. data/third_party/upb/upb/reflection/enum_def.h +1 -0
  2201. data/third_party/upb/upb/reflection/enum_value_def.c +3 -8
  2202. data/third_party/upb/upb/reflection/field_def.c +69 -29
  2203. data/third_party/upb/upb/reflection/field_def.h +4 -0
  2204. data/third_party/upb/upb/reflection/file_def.c +30 -4
  2205. data/third_party/upb/upb/reflection/file_def.h +3 -0
  2206. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  2207. data/third_party/upb/upb/reflection/message.c +26 -9
  2208. data/third_party/upb/upb/reflection/message.h +2 -2
  2209. data/third_party/upb/upb/reflection/message_def.c +14 -9
  2210. data/third_party/upb/upb/reflection/method_def.h +8 -7
  2211. data/third_party/upb/upb/reflection/service_def.h +6 -5
  2212. data/third_party/upb/upb/text/encode.c +60 -389
  2213. data/third_party/upb/upb/text/encode.h +1 -11
  2214. data/third_party/upb/upb/text/internal/encode.c +180 -0
  2215. data/third_party/upb/upb/text/internal/encode.h +240 -0
  2216. data/third_party/upb/upb/text/options.h +22 -0
  2217. data/third_party/upb/upb/wire/decode.c +160 -94
  2218. data/third_party/upb/upb/wire/decode.h +14 -1
  2219. data/third_party/upb/upb/wire/encode.c +89 -48
  2220. data/third_party/upb/upb/wire/encode.h +12 -1
  2221. data/third_party/upb/upb/wire/eps_copy_input_stream.h +3 -3
  2222. data/third_party/upb/upb/wire/internal/decode_fast.c +28 -29
  2223. data/third_party/upb/upb/wire/internal/reader.h +3 -3
  2224. data/third_party/upb/upb/wire/reader.c +1 -2
  2225. data/third_party/upb/upb/wire/reader.h +4 -8
  2226. metadata +360 -275
  2227. data/src/core/client_channel/config_selector.cc +0 -60
  2228. data/src/core/ext/transport/chttp2/transport/http_trace.cc +0 -19
  2229. data/src/core/ext/transport/chttp2/transport/http_trace.h +0 -24
  2230. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.cc +0 -45
  2231. data/src/core/ext/transport/chttp2/transport/max_concurrent_streams_policy.h +0 -67
  2232. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  2233. data/src/core/handshaker/security/tsi_error.cc +0 -31
  2234. data/src/core/handshaker/security/tsi_error.h +0 -30
  2235. data/src/core/lib/channel/channel_stack_trace.cc +0 -19
  2236. data/src/core/lib/channel/channel_stack_trace.h +0 -24
  2237. data/src/core/lib/channel/context.h +0 -105
  2238. data/src/core/lib/channel/metrics.cc +0 -334
  2239. data/src/core/lib/channel/metrics.h +0 -365
  2240. data/src/core/lib/event_engine/trace.cc +0 -25
  2241. data/src/core/lib/event_engine/trace.h +0 -48
  2242. data/src/core/lib/gpr/android/log.cc +0 -79
  2243. data/src/core/lib/gpr/linux/log.cc +0 -114
  2244. data/src/core/lib/gpr/log.cc +0 -166
  2245. data/src/core/lib/gpr/posix/log.cc +0 -111
  2246. data/src/core/lib/gpr/windows/log.cc +0 -116
  2247. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  2248. data/src/core/lib/promise/trace.cc +0 -20
  2249. data/src/core/lib/promise/trace.h +0 -24
  2250. data/src/core/lib/resource_quota/trace.cc +0 -19
  2251. data/src/core/lib/resource_quota/trace.h +0 -24
  2252. data/src/core/lib/slice/slice_refcount.cc +0 -20
  2253. data/src/core/lib/surface/api_trace.cc +0 -25
  2254. data/src/core/lib/surface/api_trace.h +0 -52
  2255. data/src/core/lib/surface/call_trace.h +0 -24
  2256. data/src/core/lib/surface/wait_for_cq_end_op.cc +0 -75
  2257. data/src/core/lib/surface/wait_for_cq_end_op.h +0 -72
  2258. data/src/core/lib/transport/batch_builder.cc +0 -172
  2259. data/src/core/lib/transport/batch_builder.h +0 -474
  2260. data/src/core/resolver/binder/binder_resolver.cc +0 -154
  2261. data/src/core/resolver/xds/xds_resolver_trace.cc +0 -25
  2262. data/src/core/resolver/xds/xds_resolver_trace.h +0 -30
  2263. data/src/core/xds/xds_client/xds_client_stats.cc +0 -172
  2264. data/src/core/xds/xds_client/xds_client_stats.h +0 -258
  2265. data/third_party/abseil-cpp/absl/strings/internal/has_absl_stringify.h +0 -44
  2266. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -122
  2267. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{aes_nohw.c → aes_nohw.c.inc} +0 -0
  2268. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{key_wrap.c → key_wrap.c.inc} +0 -0
  2269. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/{mode_wrappers.c → mode_wrappers.c.inc} +0 -0
  2270. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{add.c → add.c.inc} +0 -0
  2271. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/{x86_64-gcc.c → x86_64-gcc.c.inc} +0 -0
  2272. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{bn.c → bn.c.inc} +0 -0
  2273. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{bytes.c → bytes.c.inc} +0 -0
  2274. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{cmp.c → cmp.c.inc} +0 -0
  2275. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{ctx.c → ctx.c.inc} +0 -0
  2276. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{div_extra.c → div_extra.c.inc} +0 -0
  2277. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{gcd.c → gcd.c.inc} +0 -0
  2278. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{gcd_extra.c → gcd_extra.c.inc} +0 -0
  2279. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{generic.c → generic.c.inc} +0 -0
  2280. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{jacobi.c → jacobi.c.inc} +0 -0
  2281. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{montgomery.c → montgomery.c.inc} +0 -0
  2282. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{montgomery_inv.c → montgomery_inv.c.inc} +0 -0
  2283. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{mul.c → mul.c.inc} +0 -0
  2284. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{prime.c → prime.c.inc} +0 -0
  2285. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{rsaz_exp.c → rsaz_exp.c.inc} +0 -0
  2286. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/{shift.c → shift.c.inc} +0 -0
  2287. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{aead.c → aead.c.inc} +0 -0
  2288. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{cipher.c → cipher.c.inc} +0 -0
  2289. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/{e_aesccm.c → e_aesccm.c.inc} +0 -0
  2290. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cmac/{cmac.c → cmac.c.inc} +0 -0
  2291. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/{check.c → check.c.inc} +0 -0
  2292. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/{dh.c → dh.c.inc} +0 -0
  2293. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/{digest.c → digest.c.inc} +0 -0
  2294. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/{digests.c → digests.c.inc} +0 -0
  2295. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digestsign/{digestsign.c → digestsign.c.inc} +0 -0
  2296. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{ec.c → ec.c.inc} +0 -0
  2297. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{ec_montgomery.c → ec_montgomery.c.inc} +0 -0
  2298. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{felem.c → felem.c.inc} +0 -0
  2299. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{oct.c → oct.c.inc} +0 -0
  2300. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p224-64.c → p224-64.c.inc} +0 -0
  2301. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{p256.c → p256.c.inc} +0 -0
  2302. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{scalar.c → scalar.c.inc} +0 -0
  2303. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{simple.c → simple.c.inc} +0 -0
  2304. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{simple_mul.c → simple_mul.c.inc} +0 -0
  2305. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{util.c → util.c.inc} +0 -0
  2306. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/{wnaf.c → wnaf.c.inc} +0 -0
  2307. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/{ecdh.c → ecdh.c.inc} +0 -0
  2308. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hkdf/{hkdf.c → hkdf.c.inc} +0 -0
  2309. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/{hmac.c → hmac.c.inc} +0 -0
  2310. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/{md4.c → md4.c.inc} +0 -0
  2311. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/{md5.c → md5.c.inc} +0 -0
  2312. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{cbc.c → cbc.c.inc} +0 -0
  2313. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{cfb.c → cfb.c.inc} +0 -0
  2314. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{ctr.c → ctr.c.inc} +0 -0
  2315. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{gcm.c → gcm.c.inc} +0 -0
  2316. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{gcm_nohw.c → gcm_nohw.c.inc} +0 -0
  2317. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{ofb.c → ofb.c.inc} +0 -0
  2318. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/{polyval.c → polyval.c.inc} +0 -0
  2319. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/{ctrdrbg.c → ctrdrbg.c.inc} +0 -0
  2320. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{blinding.c → blinding.c.inc} +0 -0
  2321. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/{rsa.c → rsa.c.inc} +0 -0
  2322. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/{sha1.c → sha1.c.inc} +0 -0
  2323. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/{sha256.c → sha256.c.inc} +0 -0
  2324. /data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/{kdf.c → kdf.c.inc} +0 -0
  2325. /data/third_party/boringssl-with-bazel/src/crypto/{fipsmodule/rand → rand_extra}/getrandom_fillin.h +0 -0
@@ -0,0 +1,1292 @@
1
+ //
2
+ // Copyright 2018 gRPC authors.
3
+ //
4
+ // Licensed under the Apache License, Version 2.0 (the "License");
5
+ // you may not use this file except in compliance with the License.
6
+ // You may obtain a copy of the License at
7
+ //
8
+ // http://www.apache.org/licenses/LICENSE-2.0
9
+ //
10
+ // Unless required by applicable law or agreed to in writing, software
11
+ // distributed under the License is distributed on an "AS IS" BASIS,
12
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ // See the License for the specific language governing permissions and
14
+ // limitations under the License.
15
+ //
16
+
17
+ #include "src/core/xds/xds_client/lrs_client.h"
18
+
19
+ #include <grpc/event_engine/event_engine.h>
20
+
21
+ #include <memory>
22
+ #include <set>
23
+ #include <string>
24
+ #include <vector>
25
+
26
+ #include "absl/cleanup/cleanup.h"
27
+ #include "absl/log/check.h"
28
+ #include "absl/log/log.h"
29
+ #include "absl/strings/string_view.h"
30
+ #include "absl/types/optional.h"
31
+ #include "envoy/config/core/v3/base.upb.h"
32
+ #include "envoy/config/endpoint/v3/load_report.upb.h"
33
+ #include "envoy/service/load_stats/v3/lrs.upb.h"
34
+ #include "envoy/service/load_stats/v3/lrs.upbdefs.h"
35
+ #include "google/protobuf/duration.upb.h"
36
+ #include "src/core/lib/debug/trace.h"
37
+ #include "src/core/lib/iomgr/exec_ctx.h"
38
+ #include "src/core/util/backoff.h"
39
+ #include "src/core/util/debug_location.h"
40
+ #include "src/core/util/env.h"
41
+ #include "src/core/util/orphanable.h"
42
+ #include "src/core/util/ref_counted_ptr.h"
43
+ #include "src/core/util/string.h"
44
+ #include "src/core/util/sync.h"
45
+ #include "src/core/util/upb_utils.h"
46
+ #include "src/core/util/uri.h"
47
+ #include "src/core/xds/xds_client/xds_api.h"
48
+ #include "src/core/xds/xds_client/xds_bootstrap.h"
49
+ #include "src/core/xds/xds_client/xds_locality.h"
50
+ #include "upb/base/string_view.h"
51
+ #include "upb/mem/arena.h"
52
+ #include "upb/reflection/def.h"
53
+ #include "upb/text/encode.h"
54
+
55
+ #define GRPC_XDS_INITIAL_CONNECT_BACKOFF_SECONDS 1
56
+ #define GRPC_XDS_RECONNECT_BACKOFF_MULTIPLIER 1.6
57
+ #define GRPC_XDS_RECONNECT_MAX_BACKOFF_SECONDS 120
58
+ #define GRPC_XDS_RECONNECT_JITTER 0.2
59
+ #define GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS 1000
60
+
61
+ namespace grpc_core {
62
+
63
+ using ::grpc_event_engine::experimental::EventEngine;
64
+
65
+ // TODO(roth): Remove this once the feature passes interop tests.
66
+ bool XdsOrcaLrsPropagationChangesEnabled() {
67
+ auto value = GetEnv("GRPC_EXPERIMENTAL_XDS_ORCA_LRS_PROPAGATION");
68
+ if (!value.has_value()) return false;
69
+ bool parsed_value;
70
+ bool parse_succeeded = gpr_parse_bool_value(value->c_str(), &parsed_value);
71
+ return parse_succeeded && parsed_value;
72
+ }
73
+
74
+ namespace {
75
+
76
+ uint64_t GetAndResetCounter(std::atomic<uint64_t>* from) {
77
+ return from->exchange(0, std::memory_order_relaxed);
78
+ }
79
+
80
+ } // namespace
81
+
82
+ //
83
+ // LrsClient::ClusterDropStats
84
+ //
85
+
86
+ LrsClient::ClusterDropStats::ClusterDropStats(
87
+ RefCountedPtr<LrsClient> lrs_client, absl::string_view lrs_server,
88
+ absl::string_view cluster_name, absl::string_view eds_service_name)
89
+ : RefCounted(GRPC_TRACE_FLAG_ENABLED(xds_client_refcount)
90
+ ? "ClusterDropStats"
91
+ : nullptr),
92
+ lrs_client_(std::move(lrs_client)),
93
+ lrs_server_(lrs_server),
94
+ cluster_name_(cluster_name),
95
+ eds_service_name_(eds_service_name) {
96
+ GRPC_TRACE_LOG(xds_client, INFO)
97
+ << "[lrs_client " << lrs_client_.get() << "] created drop stats " << this
98
+ << " for {" << lrs_server_ << ", " << cluster_name_ << ", "
99
+ << eds_service_name_ << "}";
100
+ }
101
+
102
+ LrsClient::ClusterDropStats::~ClusterDropStats() {
103
+ GRPC_TRACE_LOG(xds_client, INFO)
104
+ << "[lrs_client " << lrs_client_.get() << "] destroying drop stats "
105
+ << this << " for {" << lrs_server_ << ", " << cluster_name_ << ", "
106
+ << eds_service_name_ << "}";
107
+ lrs_client_->RemoveClusterDropStats(lrs_server_, cluster_name_,
108
+ eds_service_name_, this);
109
+ lrs_client_.reset(DEBUG_LOCATION, "ClusterDropStats");
110
+ }
111
+
112
+ LrsClient::ClusterDropStats::Snapshot
113
+ LrsClient::ClusterDropStats::GetSnapshotAndReset() {
114
+ Snapshot snapshot;
115
+ snapshot.uncategorized_drops = GetAndResetCounter(&uncategorized_drops_);
116
+ MutexLock lock(&mu_);
117
+ snapshot.categorized_drops = std::move(categorized_drops_);
118
+ return snapshot;
119
+ }
120
+
121
+ void LrsClient::ClusterDropStats::AddUncategorizedDrops() {
122
+ uncategorized_drops_.fetch_add(1);
123
+ }
124
+
125
+ void LrsClient::ClusterDropStats::AddCallDropped(const std::string& category) {
126
+ MutexLock lock(&mu_);
127
+ ++categorized_drops_[category];
128
+ }
129
+
130
+ //
131
+ // LrsClient::ClusterLocalityStats
132
+ //
133
+
134
+ LrsClient::ClusterLocalityStats::ClusterLocalityStats(
135
+ RefCountedPtr<LrsClient> lrs_client, absl::string_view lrs_server,
136
+ absl::string_view cluster_name, absl::string_view eds_service_name,
137
+ RefCountedPtr<XdsLocalityName> name,
138
+ RefCountedPtr<const BackendMetricPropagation> backend_metric_propagation)
139
+ : RefCounted(GRPC_TRACE_FLAG_ENABLED(xds_client_refcount)
140
+ ? "ClusterLocalityStats"
141
+ : nullptr),
142
+ lrs_client_(std::move(lrs_client)),
143
+ lrs_server_(lrs_server),
144
+ cluster_name_(cluster_name),
145
+ eds_service_name_(eds_service_name),
146
+ name_(std::move(name)),
147
+ backend_metric_propagation_(std::move(backend_metric_propagation)) {
148
+ GRPC_TRACE_LOG(xds_client, INFO)
149
+ << "[lrs_client " << lrs_client_.get() << "] created locality stats "
150
+ << this << " for {" << lrs_server_ << ", " << cluster_name_ << ", "
151
+ << eds_service_name_ << ", "
152
+ << (name_ == nullptr ? "<none>" : name_->human_readable_string().c_str())
153
+ << ", propagation=" << backend_metric_propagation_->AsString() << "}";
154
+ }
155
+
156
+ LrsClient::ClusterLocalityStats::~ClusterLocalityStats() {
157
+ GRPC_TRACE_LOG(xds_client, INFO)
158
+ << "[lrs_client " << lrs_client_.get() << "] destroying locality stats "
159
+ << this << " for {" << lrs_server_ << ", " << cluster_name_ << ", "
160
+ << eds_service_name_ << ", "
161
+ << (name_ == nullptr ? "<none>" : name_->human_readable_string().c_str())
162
+ << ", propagation=" << backend_metric_propagation_->AsString() << "}";
163
+ lrs_client_->RemoveClusterLocalityStats(lrs_server_, cluster_name_,
164
+ eds_service_name_, name_,
165
+ backend_metric_propagation_, this);
166
+ lrs_client_.reset(DEBUG_LOCATION, "ClusterLocalityStats");
167
+ }
168
+
169
+ LrsClient::ClusterLocalityStats::Snapshot
170
+ LrsClient::ClusterLocalityStats::GetSnapshotAndReset() {
171
+ Snapshot snapshot;
172
+ for (auto& percpu_stats : stats_) {
173
+ Snapshot percpu_snapshot = {
174
+ GetAndResetCounter(&percpu_stats.total_successful_requests),
175
+ // Don't reset total_requests_in_progress because it's
176
+ // not related to a single reporting interval.
177
+ percpu_stats.total_requests_in_progress.load(std::memory_order_relaxed),
178
+ GetAndResetCounter(&percpu_stats.total_error_requests),
179
+ GetAndResetCounter(&percpu_stats.total_issued_requests),
180
+ {},
181
+ {},
182
+ {},
183
+ {}};
184
+ {
185
+ MutexLock lock(&percpu_stats.backend_metrics_mu);
186
+ percpu_snapshot.cpu_utilization = std::move(percpu_stats.cpu_utilization);
187
+ percpu_snapshot.mem_utilization = std::move(percpu_stats.mem_utilization);
188
+ percpu_snapshot.application_utilization =
189
+ std::move(percpu_stats.application_utilization);
190
+ percpu_snapshot.backend_metrics = std::move(percpu_stats.backend_metrics);
191
+ }
192
+ snapshot += percpu_snapshot;
193
+ }
194
+ return snapshot;
195
+ }
196
+
197
+ void LrsClient::ClusterLocalityStats::AddCallStarted() {
198
+ Stats& stats = stats_.this_cpu();
199
+ stats.total_issued_requests.fetch_add(1, std::memory_order_relaxed);
200
+ stats.total_requests_in_progress.fetch_add(1, std::memory_order_relaxed);
201
+ }
202
+
203
+ void LrsClient::ClusterLocalityStats::AddCallFinished(
204
+ const BackendMetricData* backend_metrics, bool fail) {
205
+ Stats& stats = stats_.this_cpu();
206
+ std::atomic<uint64_t>& to_increment =
207
+ fail ? stats.total_error_requests : stats.total_successful_requests;
208
+ to_increment.fetch_add(1, std::memory_order_relaxed);
209
+ stats.total_requests_in_progress.fetch_add(-1, std::memory_order_acq_rel);
210
+ if (backend_metrics == nullptr) return;
211
+ MutexLock lock(&stats.backend_metrics_mu);
212
+ if (!XdsOrcaLrsPropagationChangesEnabled()) {
213
+ for (const auto& m : backend_metrics->named_metrics) {
214
+ stats.backend_metrics[std::string(m.first)] += BackendMetric(1, m.second);
215
+ }
216
+ return;
217
+ }
218
+ if (backend_metric_propagation_->propagation_bits &
219
+ BackendMetricPropagation::kCpuUtilization) {
220
+ stats.cpu_utilization += BackendMetric(1, backend_metrics->cpu_utilization);
221
+ }
222
+ if (backend_metric_propagation_->propagation_bits &
223
+ BackendMetricPropagation::kMemUtilization) {
224
+ stats.mem_utilization += BackendMetric(1, backend_metrics->mem_utilization);
225
+ }
226
+ if (backend_metric_propagation_->propagation_bits &
227
+ BackendMetricPropagation::kApplicationUtilization) {
228
+ stats.application_utilization +=
229
+ BackendMetric(1, backend_metrics->application_utilization);
230
+ }
231
+ if (backend_metric_propagation_->propagation_bits &
232
+ BackendMetricPropagation::kNamedMetricsAll ||
233
+ !backend_metric_propagation_->named_metric_keys.empty()) {
234
+ for (const auto& m : backend_metrics->named_metrics) {
235
+ if (backend_metric_propagation_->propagation_bits &
236
+ BackendMetricPropagation::kNamedMetricsAll ||
237
+ backend_metric_propagation_->named_metric_keys.contains(m.first)) {
238
+ stats.backend_metrics[absl::StrCat("named_metrics.", m.first)] +=
239
+ BackendMetric(1, m.second);
240
+ }
241
+ }
242
+ }
243
+ }
244
+
245
+ //
246
+ // Internal class declarations
247
+ //
248
+
249
+ // A call wrapper that can restart a call upon failure.
250
+ // The template parameter is the kind of wrapped call.
251
+ // TODO(roth): This is basically the same code as in XdsClient, and
252
+ // probably very similar to many other places in the codebase.
253
+ // Consider refactoring this into a common utility library somehow.
254
+ template <typename T>
255
+ class LrsClient::LrsChannel::RetryableCall final
256
+ : public InternallyRefCounted<RetryableCall<T>> {
257
+ public:
258
+ explicit RetryableCall(WeakRefCountedPtr<LrsChannel> lrs_channel);
259
+
260
+ // Disable thread-safety analysis because this method is called via
261
+ // OrphanablePtr<>, but there's no way to pass the lock annotation
262
+ // through there.
263
+ void Orphan() override ABSL_NO_THREAD_SAFETY_ANALYSIS;
264
+
265
+ void OnCallFinishedLocked() ABSL_EXCLUSIVE_LOCKS_REQUIRED(&LrsClient::mu_);
266
+
267
+ T* call() const { return call_.get(); }
268
+ LrsChannel* lrs_channel() const { return lrs_channel_.get(); }
269
+
270
+ bool IsCurrentCallOnChannel() const;
271
+
272
+ private:
273
+ void StartNewCallLocked();
274
+ void StartRetryTimerLocked() ABSL_EXCLUSIVE_LOCKS_REQUIRED(&LrsClient::mu_);
275
+
276
+ void OnRetryTimer();
277
+
278
+ // The wrapped xds call that talks to the xds server. It's instantiated
279
+ // every time we start a new call. It's null during call retry backoff.
280
+ OrphanablePtr<T> call_;
281
+ // The owning xds channel.
282
+ WeakRefCountedPtr<LrsChannel> lrs_channel_;
283
+
284
+ // Retry state.
285
+ BackOff backoff_;
286
+ absl::optional<EventEngine::TaskHandle> timer_handle_
287
+ ABSL_GUARDED_BY(&LrsClient::mu_);
288
+
289
+ bool shutting_down_ = false;
290
+ };
291
+
292
+ // An LRS call to the LRS server.
293
+ class LrsClient::LrsChannel::LrsCall final
294
+ : public InternallyRefCounted<LrsCall> {
295
+ public:
296
+ // The ctor and dtor should not be used directly.
297
+ explicit LrsCall(RefCountedPtr<RetryableCall<LrsCall>> retryable_call);
298
+
299
+ void Orphan() override;
300
+
301
+ RetryableCall<LrsCall>* retryable_call() { return retryable_call_.get(); }
302
+ LrsChannel* lrs_channel() const { return retryable_call_->lrs_channel(); }
303
+ LrsClient* lrs_client() const { return lrs_channel()->lrs_client(); }
304
+ bool seen_response() const { return seen_response_; }
305
+
306
+ private:
307
+ class StreamEventHandler final
308
+ : public XdsTransportFactory::XdsTransport::StreamingCall::EventHandler {
309
+ public:
310
+ explicit StreamEventHandler(RefCountedPtr<LrsCall> lrs_call)
311
+ : lrs_call_(std::move(lrs_call)) {}
312
+
313
+ void OnRequestSent(bool /*ok*/) override { lrs_call_->OnRequestSent(); }
314
+ void OnRecvMessage(absl::string_view payload) override {
315
+ lrs_call_->OnRecvMessage(payload);
316
+ }
317
+ void OnStatusReceived(absl::Status status) override {
318
+ lrs_call_->OnStatusReceived(std::move(status));
319
+ }
320
+
321
+ private:
322
+ RefCountedPtr<LrsCall> lrs_call_;
323
+ };
324
+
325
+ // A repeating timer for a particular duration.
326
+ class Timer final : public InternallyRefCounted<Timer> {
327
+ public:
328
+ explicit Timer(RefCountedPtr<LrsCall> lrs_call)
329
+ : lrs_call_(std::move(lrs_call)) {}
330
+ ~Timer() override { lrs_call_.reset(DEBUG_LOCATION, "LRS timer"); }
331
+
332
+ // Disable thread-safety analysis because this method is called via
333
+ // OrphanablePtr<>, but there's no way to pass the lock annotation
334
+ // through there.
335
+ void Orphan() override ABSL_NO_THREAD_SAFETY_ANALYSIS;
336
+
337
+ void ScheduleNextReportLocked()
338
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&LrsClient::mu_);
339
+
340
+ private:
341
+ bool IsCurrentTimerOnCall() const {
342
+ return this == lrs_call_->timer_.get();
343
+ }
344
+ LrsClient* lrs_client() const { return lrs_call_->lrs_client(); }
345
+
346
+ void OnNextReportTimer();
347
+
348
+ // The owning LRS call.
349
+ RefCountedPtr<LrsCall> lrs_call_;
350
+
351
+ absl::optional<EventEngine::TaskHandle> timer_handle_
352
+ ABSL_GUARDED_BY(&LrsClient::mu_);
353
+ };
354
+
355
+ void MaybeScheduleNextReportLocked()
356
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&LrsClient::mu_);
357
+
358
+ void SendReportLocked() ABSL_EXCLUSIVE_LOCKS_REQUIRED(&LrsClient::mu_);
359
+
360
+ void SendMessageLocked(std::string payload)
361
+ ABSL_EXCLUSIVE_LOCKS_REQUIRED(&LrsClient::mu_);
362
+
363
+ void OnRequestSent();
364
+ void OnRecvMessage(absl::string_view payload);
365
+ void OnStatusReceived(absl::Status status);
366
+
367
+ bool IsCurrentCallOnChannel() const;
368
+
369
+ // The owning RetryableCall<>.
370
+ RefCountedPtr<RetryableCall<LrsCall>> retryable_call_;
371
+
372
+ OrphanablePtr<XdsTransportFactory::XdsTransport::StreamingCall>
373
+ streaming_call_;
374
+
375
+ bool seen_response_ = false;
376
+ bool send_message_pending_ ABSL_GUARDED_BY(&LrsClient::mu_) = false;
377
+
378
+ // Load reporting state.
379
+ bool send_all_clusters_ = false;
380
+ std::set<std::string> cluster_names_; // Asked for by the LRS server.
381
+ Duration load_reporting_interval_;
382
+ bool last_report_counters_were_zero_ = false;
383
+ OrphanablePtr<Timer> timer_;
384
+ };
385
+
386
+ //
387
+ // LrsClient::LrsChannel
388
+ //
389
+
390
+ LrsClient::LrsChannel::LrsChannel(
391
+ WeakRefCountedPtr<LrsClient> lrs_client,
392
+ std::shared_ptr<const XdsBootstrap::XdsServer> server)
393
+ : DualRefCounted<LrsChannel>(GRPC_TRACE_FLAG_ENABLED(xds_client_refcount)
394
+ ? "LrsChannel"
395
+ : nullptr),
396
+ lrs_client_(std::move(lrs_client)),
397
+ server_(std::move(server)) {
398
+ GRPC_TRACE_LOG(xds_client, INFO)
399
+ << "[lrs_client " << lrs_client_.get() << "] creating channel " << this
400
+ << " for server " << server_->server_uri();
401
+ absl::Status status;
402
+ transport_ = lrs_client_->transport_factory_->GetTransport(*server_, &status);
403
+ CHECK(transport_ != nullptr);
404
+ if (!status.ok()) {
405
+ LOG(ERROR) << "Error creating LRS channel to " << server_->server_uri()
406
+ << ": " << status;
407
+ }
408
+ }
409
+
410
+ LrsClient::LrsChannel::~LrsChannel() {
411
+ GRPC_TRACE_LOG(xds_client, INFO)
412
+ << "[lrs_client " << lrs_client() << "] destroying lrs channel " << this
413
+ << " for server " << server_->server_uri();
414
+ lrs_client_.reset(DEBUG_LOCATION, "LrsChannel");
415
+ }
416
+
417
+ // This method should only ever be called when holding the lock, but we can't
418
+ // use a ABSL_EXCLUSIVE_LOCKS_REQUIRED annotation, because Orphan() will be
419
+ // called from DualRefCounted::Unref(), which cannot have a lock annotation for
420
+ // a lock in this subclass.
421
+ void LrsClient::LrsChannel::Orphaned() ABSL_NO_THREAD_SAFETY_ANALYSIS {
422
+ GRPC_TRACE_LOG(xds_client, INFO)
423
+ << "[lrs_client " << lrs_client() << "] orphaning lrs channel " << this
424
+ << " for server " << server_->server_uri();
425
+ transport_.reset();
426
+ // At this time, all strong refs are removed, remove from channel map to
427
+ // prevent subsequent subscription from trying to use this LrsChannel as
428
+ // it is shutting down.
429
+ lrs_client_->lrs_channel_map_.erase(server_->Key());
430
+ lrs_call_.reset();
431
+ }
432
+
433
+ void LrsClient::LrsChannel::ResetBackoff() { transport_->ResetBackoff(); }
434
+
435
+ void LrsClient::LrsChannel::MaybeStartLrsCall() {
436
+ if (lrs_call_ != nullptr) return;
437
+ lrs_call_ = MakeOrphanable<RetryableCall<LrsCall>>(
438
+ WeakRef(DEBUG_LOCATION, "LrsCall"));
439
+ }
440
+
441
+ void LrsClient::LrsChannel::StopLrsCallLocked() {
442
+ lrs_client_->load_report_map_.erase(server_->Key());
443
+ lrs_call_.reset();
444
+ }
445
+
446
+ //
447
+ // LrsClient::LrsChannel::RetryableCall<>
448
+ //
449
+
450
+ template <typename T>
451
+ LrsClient::LrsChannel::RetryableCall<T>::RetryableCall(
452
+ WeakRefCountedPtr<LrsChannel> lrs_channel)
453
+ : lrs_channel_(std::move(lrs_channel)),
454
+ backoff_(BackOff::Options()
455
+ .set_initial_backoff(Duration::Seconds(
456
+ GRPC_XDS_INITIAL_CONNECT_BACKOFF_SECONDS))
457
+ .set_multiplier(GRPC_XDS_RECONNECT_BACKOFF_MULTIPLIER)
458
+ .set_jitter(GRPC_XDS_RECONNECT_JITTER)
459
+ .set_max_backoff(Duration::Seconds(
460
+ GRPC_XDS_RECONNECT_MAX_BACKOFF_SECONDS))) {
461
+ StartNewCallLocked();
462
+ }
463
+
464
+ template <typename T>
465
+ void LrsClient::LrsChannel::RetryableCall<T>::Orphan() {
466
+ shutting_down_ = true;
467
+ call_.reset();
468
+ if (timer_handle_.has_value()) {
469
+ lrs_channel()->lrs_client()->engine()->Cancel(*timer_handle_);
470
+ timer_handle_.reset();
471
+ }
472
+ this->Unref(DEBUG_LOCATION, "RetryableCall+orphaned");
473
+ }
474
+
475
+ template <typename T>
476
+ void LrsClient::LrsChannel::RetryableCall<T>::OnCallFinishedLocked() {
477
+ // If we saw a response on the current stream, reset backoff.
478
+ if (call_->seen_response()) backoff_.Reset();
479
+ call_.reset();
480
+ // Start retry timer.
481
+ StartRetryTimerLocked();
482
+ }
483
+
484
+ template <typename T>
485
+ void LrsClient::LrsChannel::RetryableCall<T>::StartNewCallLocked() {
486
+ if (shutting_down_) return;
487
+ CHECK(lrs_channel_->transport_ != nullptr);
488
+ CHECK(call_ == nullptr);
489
+ GRPC_TRACE_LOG(xds_client, INFO)
490
+ << "[lrs_client " << lrs_channel()->lrs_client() << "] lrs server "
491
+ << lrs_channel()->server_->server_uri()
492
+ << ": start new call from retryable call " << this;
493
+ call_ = MakeOrphanable<T>(
494
+ this->Ref(DEBUG_LOCATION, "RetryableCall+start_new_call"));
495
+ }
496
+
497
+ template <typename T>
498
+ void LrsClient::LrsChannel::RetryableCall<T>::StartRetryTimerLocked() {
499
+ if (shutting_down_) return;
500
+ const Duration delay = backoff_.NextAttemptDelay();
501
+ GRPC_TRACE_LOG(xds_client, INFO)
502
+ << "[lrs_client " << lrs_channel()->lrs_client() << "] lrs server "
503
+ << lrs_channel()->server_->server_uri()
504
+ << ": call attempt failed; retry timer will fire in " << delay.millis()
505
+ << "ms.";
506
+ timer_handle_ = lrs_channel()->lrs_client()->engine()->RunAfter(
507
+ delay,
508
+ [self = this->Ref(DEBUG_LOCATION, "RetryableCall+retry_timer_start")]() {
509
+ ApplicationCallbackExecCtx callback_exec_ctx;
510
+ ExecCtx exec_ctx;
511
+ self->OnRetryTimer();
512
+ });
513
+ }
514
+
515
+ template <typename T>
516
+ void LrsClient::LrsChannel::RetryableCall<T>::OnRetryTimer() {
517
+ MutexLock lock(&lrs_channel_->lrs_client()->mu_);
518
+ if (timer_handle_.has_value()) {
519
+ timer_handle_.reset();
520
+ if (shutting_down_) return;
521
+ GRPC_TRACE_LOG(xds_client, INFO)
522
+ << "[lrs_client " << lrs_channel()->lrs_client() << "] lrs server "
523
+ << lrs_channel()->server_->server_uri()
524
+ << ": retry timer fired (retryable call: " << this << ")";
525
+ StartNewCallLocked();
526
+ }
527
+ }
528
+
529
+ //
530
+ // LrsClient::LrsChannel::LrsCall::Timer
531
+ //
532
+
533
+ void LrsClient::LrsChannel::LrsCall::Timer::Orphan() {
534
+ if (timer_handle_.has_value()) {
535
+ lrs_client()->engine()->Cancel(*timer_handle_);
536
+ timer_handle_.reset();
537
+ }
538
+ Unref(DEBUG_LOCATION, "Orphan");
539
+ }
540
+
541
+ void LrsClient::LrsChannel::LrsCall::Timer::ScheduleNextReportLocked() {
542
+ GRPC_TRACE_LOG(xds_client, INFO)
543
+ << "[lrs_client " << lrs_client() << "] lrs server "
544
+ << lrs_call_->lrs_channel()->server_->server_uri()
545
+ << ": scheduling next load report in "
546
+ << lrs_call_->load_reporting_interval_;
547
+ timer_handle_ = lrs_client()->engine()->RunAfter(
548
+ lrs_call_->load_reporting_interval_,
549
+ [self = Ref(DEBUG_LOCATION, "timer")]() {
550
+ ApplicationCallbackExecCtx callback_exec_ctx;
551
+ ExecCtx exec_ctx;
552
+ self->OnNextReportTimer();
553
+ });
554
+ }
555
+
556
+ void LrsClient::LrsChannel::LrsCall::Timer::OnNextReportTimer() {
557
+ MutexLock lock(&lrs_client()->mu_);
558
+ timer_handle_.reset();
559
+ if (IsCurrentTimerOnCall()) lrs_call_->SendReportLocked();
560
+ }
561
+
562
+ //
563
+ // LrsClient::LrsChannel::LrsCall
564
+ //
565
+
566
+ LrsClient::LrsChannel::LrsCall::LrsCall(
567
+ RefCountedPtr<RetryableCall<LrsCall>> retryable_call)
568
+ : InternallyRefCounted<LrsCall>(
569
+ GRPC_TRACE_FLAG_ENABLED(xds_client_refcount) ? "LrsCall" : nullptr),
570
+ retryable_call_(std::move(retryable_call)) {
571
+ // Init the LRS call. Note that the call will progress every time there's
572
+ // activity in lrs_client()->interested_parties_, which is comprised of
573
+ // the polling entities from client_channel.
574
+ CHECK_NE(lrs_client(), nullptr);
575
+ const char* method =
576
+ "/envoy.service.load_stats.v3.LoadReportingService/StreamLoadStats";
577
+ streaming_call_ = lrs_channel()->transport_->CreateStreamingCall(
578
+ method, std::make_unique<StreamEventHandler>(
579
+ // Passing the initial ref here. This ref will go away when
580
+ // the StreamEventHandler is destroyed.
581
+ RefCountedPtr<LrsCall>(this)));
582
+ CHECK(streaming_call_ != nullptr);
583
+ // Start the call.
584
+ GRPC_TRACE_LOG(xds_client, INFO)
585
+ << "[lrs_client " << lrs_client() << "] lrs server "
586
+ << lrs_channel()->server_->server_uri()
587
+ << ": starting LRS call (lrs_call=" << this
588
+ << ", streaming_call=" << streaming_call_.get() << ")";
589
+ // Send the initial request.
590
+ std::string serialized_payload = lrs_client()->CreateLrsInitialRequest();
591
+ SendMessageLocked(std::move(serialized_payload));
592
+ // Read initial response.
593
+ streaming_call_->StartRecvMessage();
594
+ }
595
+
596
+ void LrsClient::LrsChannel::LrsCall::Orphan() {
597
+ timer_.reset();
598
+ // Note that the initial ref is held by the StreamEventHandler, which
599
+ // will be destroyed when streaming_call_ is destroyed, which may not happen
600
+ // here, since there may be other refs held to streaming_call_ by internal
601
+ // callbacks.
602
+ streaming_call_.reset();
603
+ }
604
+
605
+ void LrsClient::LrsChannel::LrsCall::MaybeScheduleNextReportLocked() {
606
+ // If there are no more registered stats to report, cancel the call.
607
+ auto it = lrs_client()->load_report_map_.find(lrs_channel()->server_->Key());
608
+ if (it == lrs_client()->load_report_map_.end() ||
609
+ it->second.load_report_map.empty()) {
610
+ it->second.lrs_channel->StopLrsCallLocked();
611
+ return;
612
+ }
613
+ // Don't start if the previous send_message op hasn't completed yet.
614
+ // If this happens, we'll be called again from OnRequestSent().
615
+ if (send_message_pending_) return;
616
+ // Don't start if no LRS response has arrived.
617
+ if (!seen_response()) return;
618
+ // If there is no timer, create one.
619
+ // This happens on the initial response and whenever the interval changes.
620
+ if (timer_ == nullptr) {
621
+ timer_ = MakeOrphanable<Timer>(Ref(DEBUG_LOCATION, "LRS timer"));
622
+ }
623
+ // Schedule the next load report.
624
+ timer_->ScheduleNextReportLocked();
625
+ }
626
+
627
+ bool LrsClient::LoadReportCountersAreZero(
628
+ const ClusterLoadReportMap& snapshot) {
629
+ for (const auto& p : snapshot) {
630
+ const ClusterLoadReport& cluster_snapshot = p.second;
631
+ if (!cluster_snapshot.dropped_requests.IsZero()) return false;
632
+ for (const auto& q : cluster_snapshot.locality_stats) {
633
+ const ClusterLocalityStats::Snapshot& locality_snapshot = q.second;
634
+ if (!locality_snapshot.IsZero()) return false;
635
+ }
636
+ }
637
+ return true;
638
+ }
639
+
640
+ void LrsClient::LrsChannel::LrsCall::SendReportLocked() {
641
+ // Construct snapshot from all reported stats.
642
+ ClusterLoadReportMap snapshot = lrs_client()->BuildLoadReportSnapshotLocked(
643
+ *lrs_channel()->server_, send_all_clusters_, cluster_names_);
644
+ // Skip client load report if the counters were all zero in the last
645
+ // report and they are still zero in this one.
646
+ const bool old_val = last_report_counters_were_zero_;
647
+ last_report_counters_were_zero_ = LoadReportCountersAreZero(snapshot);
648
+ if (old_val && last_report_counters_were_zero_) {
649
+ MaybeScheduleNextReportLocked();
650
+ return;
651
+ }
652
+ // Send a request that contains the snapshot.
653
+ std::string serialized_payload =
654
+ lrs_client()->CreateLrsRequest(std::move(snapshot));
655
+ SendMessageLocked(std::move(serialized_payload));
656
+ }
657
+
658
+ void LrsClient::LrsChannel::LrsCall::SendMessageLocked(std::string payload) {
659
+ send_message_pending_ = true;
660
+ streaming_call_->SendMessage(std::move(payload));
661
+ }
662
+
663
+ void LrsClient::LrsChannel::LrsCall::OnRequestSent() {
664
+ MutexLock lock(&lrs_client()->mu_);
665
+ send_message_pending_ = false;
666
+ if (IsCurrentCallOnChannel()) MaybeScheduleNextReportLocked();
667
+ }
668
+
669
+ void LrsClient::LrsChannel::LrsCall::OnRecvMessage(absl::string_view payload) {
670
+ MutexLock lock(&lrs_client()->mu_);
671
+ // If we're no longer the current call, ignore the result.
672
+ if (!IsCurrentCallOnChannel()) return;
673
+ // Start recv after any code branch
674
+ auto cleanup = absl::MakeCleanup(
675
+ [call = streaming_call_.get()]() { call->StartRecvMessage(); });
676
+ // Parse the response.
677
+ bool send_all_clusters = false;
678
+ std::set<std::string> new_cluster_names;
679
+ Duration new_load_reporting_interval;
680
+ absl::Status status = lrs_client()->ParseLrsResponse(
681
+ payload, &send_all_clusters, &new_cluster_names,
682
+ &new_load_reporting_interval);
683
+ if (!status.ok()) {
684
+ LOG(ERROR) << "[lrs_client " << lrs_client() << "] lrs server "
685
+ << lrs_channel()->server_->server_uri()
686
+ << ": LRS response parsing failed: " << status;
687
+ return;
688
+ }
689
+ seen_response_ = true;
690
+ if (GRPC_TRACE_FLAG_ENABLED(xds_client)) {
691
+ LOG(INFO) << "[lrs_client " << lrs_client() << "] lrs server "
692
+ << lrs_channel()->server_->server_uri()
693
+ << ": LRS response received, " << new_cluster_names.size()
694
+ << " cluster names, send_all_clusters=" << send_all_clusters
695
+ << ", load_report_interval="
696
+ << new_load_reporting_interval.millis() << "ms";
697
+ size_t i = 0;
698
+ for (const auto& name : new_cluster_names) {
699
+ LOG(INFO) << "[lrs_client " << lrs_client() << "] cluster_name " << i++
700
+ << ": " << name;
701
+ }
702
+ }
703
+ if (new_load_reporting_interval <
704
+ Duration::Milliseconds(GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS)) {
705
+ new_load_reporting_interval =
706
+ Duration::Milliseconds(GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS);
707
+ GRPC_TRACE_LOG(xds_client, INFO)
708
+ << "[lrs_client " << lrs_client() << "] lrs server "
709
+ << lrs_channel()->server_->server_uri()
710
+ << ": increased load_report_interval to minimum value "
711
+ << GRPC_XDS_MIN_CLIENT_LOAD_REPORTING_INTERVAL_MS << "ms";
712
+ }
713
+ // Ignore identical update.
714
+ if (send_all_clusters == send_all_clusters_ &&
715
+ cluster_names_ == new_cluster_names &&
716
+ load_reporting_interval_ == new_load_reporting_interval) {
717
+ GRPC_TRACE_LOG(xds_client, INFO)
718
+ << "[lrs_client " << lrs_client() << "] lrs server "
719
+ << lrs_channel()->server_->server_uri()
720
+ << ": incoming LRS response identical to current, ignoring.";
721
+ return;
722
+ }
723
+ // If the interval has changed, we'll need to restart the timer below.
724
+ const bool restart_timer =
725
+ load_reporting_interval_ != new_load_reporting_interval;
726
+ // Record the new config.
727
+ send_all_clusters_ = send_all_clusters;
728
+ cluster_names_ = std::move(new_cluster_names);
729
+ load_reporting_interval_ = new_load_reporting_interval;
730
+ // Restart timer if needed.
731
+ if (restart_timer) {
732
+ timer_.reset();
733
+ MaybeScheduleNextReportLocked();
734
+ }
735
+ }
736
+
737
+ void LrsClient::LrsChannel::LrsCall::OnStatusReceived(absl::Status status) {
738
+ MutexLock lock(&lrs_client()->mu_);
739
+ GRPC_TRACE_LOG(xds_client, INFO)
740
+ << "[lrs_client " << lrs_client() << "] lrs server "
741
+ << lrs_channel()->server_->server_uri()
742
+ << ": LRS call status received (lrs_channel=" << lrs_channel()
743
+ << ", lrs_call=" << this << ", streaming_call=" << streaming_call_.get()
744
+ << "): " << status;
745
+ // Ignore status from a stale call.
746
+ if (IsCurrentCallOnChannel()) {
747
+ // Try to restart the call.
748
+ retryable_call_->OnCallFinishedLocked();
749
+ }
750
+ }
751
+
752
+ bool LrsClient::LrsChannel::LrsCall::IsCurrentCallOnChannel() const {
753
+ // If the retryable LRS call is null (which only happens when the lrs
754
+ // channel is shutting down), all the LRS calls are stale.
755
+ if (lrs_channel()->lrs_call_ == nullptr) return false;
756
+ return this == lrs_channel()->lrs_call_->call();
757
+ }
758
+
759
+ //
760
+ // LrsClient
761
+ //
762
+
763
+ LrsClient::LrsClient(
764
+ std::shared_ptr<XdsBootstrap> bootstrap, std::string user_agent_name,
765
+ std::string user_agent_version,
766
+ RefCountedPtr<XdsTransportFactory> transport_factory,
767
+ std::shared_ptr<grpc_event_engine::experimental::EventEngine> engine)
768
+ : DualRefCounted<LrsClient>(
769
+ GRPC_TRACE_FLAG_ENABLED(xds_client_refcount) ? "LrsClient" : nullptr),
770
+ bootstrap_(std::move(bootstrap)),
771
+ user_agent_name_(std::move(user_agent_name)),
772
+ user_agent_version_(std::move(user_agent_version)),
773
+ transport_factory_(std::move(transport_factory)),
774
+ engine_(std::move(engine)) {
775
+ GRPC_TRACE_LOG(xds_client, INFO)
776
+ << "[lrs_client " << this << "] creating lrs client";
777
+ }
778
+
779
+ LrsClient::~LrsClient() {
780
+ GRPC_TRACE_LOG(xds_client, INFO)
781
+ << "[lrs_client " << this << "] destroying lrs client";
782
+ }
783
+
784
+ void LrsClient::Orphaned() {
785
+ GRPC_TRACE_LOG(xds_client, INFO)
786
+ << "[lrs_client " << this << "] shutting down lrs client";
787
+ MutexLock lock(&mu_);
788
+ // We may still be sending lingering queued load report data, so don't
789
+ // just clear the load reporting map, but we do want to clear the refs
790
+ // we're holding to the LrsChannel objects, to make sure that
791
+ // everything shuts down properly.
792
+ for (auto& p : load_report_map_) {
793
+ p.second.lrs_channel.reset(DEBUG_LOCATION, "LrsClient::Orphan()");
794
+ }
795
+ }
796
+
797
+ RefCountedPtr<LrsClient::LrsChannel> LrsClient::GetOrCreateLrsChannelLocked(
798
+ std::shared_ptr<const XdsBootstrap::XdsServer> server, const char* reason) {
799
+ std::string key = server->Key();
800
+ auto it = lrs_channel_map_.find(key);
801
+ if (it != lrs_channel_map_.end()) {
802
+ return it->second->Ref(DEBUG_LOCATION, reason);
803
+ }
804
+ // Channel not found, so create a new one.
805
+ auto lrs_channel = MakeRefCounted<LrsChannel>(
806
+ WeakRef(DEBUG_LOCATION, "LrsChannel"), std::move(server));
807
+ lrs_channel_map_[std::move(key)] = lrs_channel.get();
808
+ return lrs_channel;
809
+ }
810
+
811
+ RefCountedPtr<LrsClient::ClusterDropStats> LrsClient::AddClusterDropStats(
812
+ std::shared_ptr<const XdsBootstrap::XdsServer> lrs_server,
813
+ absl::string_view cluster_name, absl::string_view eds_service_name) {
814
+ auto key =
815
+ std::make_pair(std::string(cluster_name), std::string(eds_service_name));
816
+ RefCountedPtr<ClusterDropStats> cluster_drop_stats;
817
+ {
818
+ MutexLock lock(&mu_);
819
+ // We jump through some hoops here to make sure that the
820
+ // absl::string_views stored in the ClusterDropStats object point
821
+ // to the strings in the load_report_map_ keys, so that
822
+ // they have the same lifetime.
823
+ auto server_it =
824
+ load_report_map_.emplace(lrs_server->Key(), LoadReportServer()).first;
825
+ if (server_it->second.lrs_channel == nullptr) {
826
+ server_it->second.lrs_channel = GetOrCreateLrsChannelLocked(
827
+ lrs_server, "load report map (drop stats)");
828
+ }
829
+ auto load_report_it = server_it->second.load_report_map
830
+ .emplace(std::move(key), LoadReportState())
831
+ .first;
832
+ LoadReportState& load_report_state = load_report_it->second;
833
+ if (load_report_state.drop_stats != nullptr) {
834
+ cluster_drop_stats = load_report_state.drop_stats->RefIfNonZero();
835
+ }
836
+ if (cluster_drop_stats == nullptr) {
837
+ if (load_report_state.drop_stats != nullptr) {
838
+ load_report_state.deleted_drop_stats +=
839
+ load_report_state.drop_stats->GetSnapshotAndReset();
840
+ }
841
+ cluster_drop_stats = MakeRefCounted<ClusterDropStats>(
842
+ Ref(DEBUG_LOCATION, "DropStats"), server_it->first /*lrs_server*/,
843
+ load_report_it->first.first /*cluster_name*/,
844
+ load_report_it->first.second /*eds_service_name*/);
845
+ load_report_state.drop_stats = cluster_drop_stats.get();
846
+ }
847
+ server_it->second.lrs_channel->MaybeStartLrsCall();
848
+ }
849
+ return cluster_drop_stats;
850
+ }
851
+
852
+ void LrsClient::RemoveClusterDropStats(
853
+ absl::string_view lrs_server_key, absl::string_view cluster_name,
854
+ absl::string_view eds_service_name,
855
+ LrsClient::ClusterDropStats* cluster_drop_stats) {
856
+ MutexLock lock(&mu_);
857
+ auto server_it = load_report_map_.find(lrs_server_key);
858
+ if (server_it == load_report_map_.end()) return;
859
+ auto load_report_it = server_it->second.load_report_map.find(
860
+ std::make_pair(std::string(cluster_name), std::string(eds_service_name)));
861
+ if (load_report_it == server_it->second.load_report_map.end()) return;
862
+ LoadReportState& load_report_state = load_report_it->second;
863
+ if (load_report_state.drop_stats == cluster_drop_stats) {
864
+ // Record final snapshot in deleted_drop_stats, which will be
865
+ // added to the next load report.
866
+ load_report_state.deleted_drop_stats +=
867
+ load_report_state.drop_stats->GetSnapshotAndReset();
868
+ load_report_state.drop_stats = nullptr;
869
+ }
870
+ }
871
+
872
+ RefCountedPtr<LrsClient::ClusterLocalityStats>
873
+ LrsClient::AddClusterLocalityStats(
874
+ std::shared_ptr<const XdsBootstrap::XdsServer> lrs_server,
875
+ absl::string_view cluster_name, absl::string_view eds_service_name,
876
+ RefCountedPtr<XdsLocalityName> locality,
877
+ RefCountedPtr<const BackendMetricPropagation> backend_metric_propagation) {
878
+ auto key =
879
+ std::make_pair(std::string(cluster_name), std::string(eds_service_name));
880
+ RefCountedPtr<ClusterLocalityStats> cluster_locality_stats;
881
+ {
882
+ MutexLock lock(&mu_);
883
+ // We jump through some hoops here to make sure that the
884
+ // absl::string_views stored in the ClusterLocalityStats object point
885
+ // to the strings in the load_report_map_ keys, so that
886
+ // they have the same lifetime.
887
+ auto server_it =
888
+ load_report_map_.emplace(lrs_server->Key(), LoadReportServer()).first;
889
+ if (server_it->second.lrs_channel == nullptr) {
890
+ server_it->second.lrs_channel = GetOrCreateLrsChannelLocked(
891
+ std::move(lrs_server), "load report map (locality stats)");
892
+ }
893
+ auto load_report_it = server_it->second.load_report_map
894
+ .emplace(std::move(key), LoadReportState())
895
+ .first;
896
+ LoadReportState& load_report_state = load_report_it->second;
897
+ LoadReportState::LocalityState& locality_state =
898
+ load_report_state.locality_stats[locality];
899
+ ClusterLocalityStats*& locality_stats =
900
+ locality_state.propagation_stats[backend_metric_propagation];
901
+ if (locality_stats != nullptr) {
902
+ cluster_locality_stats = locality_stats->RefIfNonZero();
903
+ }
904
+ if (cluster_locality_stats == nullptr) {
905
+ if (locality_stats != nullptr) {
906
+ locality_state.deleted_locality_stats +=
907
+ locality_stats->GetSnapshotAndReset();
908
+ }
909
+ cluster_locality_stats = MakeRefCounted<ClusterLocalityStats>(
910
+ Ref(DEBUG_LOCATION, "LocalityStats"), server_it->first /*lrs_server*/,
911
+ load_report_it->first.first /*cluster_name*/,
912
+ load_report_it->first.second /*eds_service_name*/,
913
+ std::move(locality), std::move(backend_metric_propagation));
914
+ locality_stats = cluster_locality_stats.get();
915
+ }
916
+ server_it->second.lrs_channel->MaybeStartLrsCall();
917
+ }
918
+ return cluster_locality_stats;
919
+ }
920
+
921
+ void LrsClient::RemoveClusterLocalityStats(
922
+ absl::string_view lrs_server_key, absl::string_view cluster_name,
923
+ absl::string_view eds_service_name,
924
+ const RefCountedPtr<XdsLocalityName>& locality,
925
+ const RefCountedPtr<const BackendMetricPropagation>&
926
+ backend_metric_propagation,
927
+ ClusterLocalityStats* cluster_locality_stats) {
928
+ MutexLock lock(&mu_);
929
+ auto server_it = load_report_map_.find(lrs_server_key);
930
+ if (server_it == load_report_map_.end()) return;
931
+ auto load_report_it = server_it->second.load_report_map.find(
932
+ std::make_pair(std::string(cluster_name), std::string(eds_service_name)));
933
+ if (load_report_it == server_it->second.load_report_map.end()) return;
934
+ LoadReportState& load_report_state = load_report_it->second;
935
+ auto locality_it = load_report_state.locality_stats.find(locality);
936
+ if (locality_it == load_report_state.locality_stats.end()) return;
937
+ LoadReportState::LocalityState& locality_state = locality_it->second;
938
+ auto propagation_it =
939
+ locality_state.propagation_stats.find(backend_metric_propagation);
940
+ if (propagation_it == locality_state.propagation_stats.end()) return;
941
+ ClusterLocalityStats* locality_stats = propagation_it->second;
942
+ if (locality_stats == cluster_locality_stats) {
943
+ // Record final snapshot in deleted_locality_stats, which will be
944
+ // added to the next load report.
945
+ locality_state.deleted_locality_stats +=
946
+ locality_stats->GetSnapshotAndReset();
947
+ locality_state.propagation_stats.erase(propagation_it);
948
+ }
949
+ }
950
+
951
+ void LrsClient::ResetBackoff() {
952
+ MutexLock lock(&mu_);
953
+ for (auto& p : lrs_channel_map_) {
954
+ p.second->ResetBackoff();
955
+ }
956
+ }
957
+
958
+ LrsClient::ClusterLoadReportMap LrsClient::BuildLoadReportSnapshotLocked(
959
+ const XdsBootstrap::XdsServer& lrs_server, bool send_all_clusters,
960
+ const std::set<std::string>& clusters) {
961
+ GRPC_TRACE_LOG(xds_client, INFO)
962
+ << "[lrs_client " << this << "] start building load report";
963
+ ClusterLoadReportMap snapshot_map;
964
+ auto server_it = load_report_map_.find(lrs_server.Key());
965
+ if (server_it == load_report_map_.end()) return snapshot_map;
966
+ auto& load_report_map = server_it->second.load_report_map;
967
+ for (auto load_report_it = load_report_map.begin();
968
+ load_report_it != load_report_map.end();) {
969
+ // Cluster key is cluster and EDS service name.
970
+ const auto& cluster_key = load_report_it->first;
971
+ LoadReportState& load_report = load_report_it->second;
972
+ // If the CDS response for a cluster indicates to use LRS but the
973
+ // LRS server does not say that it wants reports for this cluster,
974
+ // then we'll have stats objects here whose data we're not going to
975
+ // include in the load report. However, we still need to clear out
976
+ // the data from the stats objects, so that if the LRS server starts
977
+ // asking for the data in the future, we don't incorrectly include
978
+ // data from previous reporting intervals in that future report.
979
+ const bool record_stats =
980
+ send_all_clusters || clusters.find(cluster_key.first) != clusters.end();
981
+ ClusterLoadReport snapshot;
982
+ // Aggregate drop stats.
983
+ snapshot.dropped_requests = std::move(load_report.deleted_drop_stats);
984
+ if (load_report.drop_stats != nullptr) {
985
+ snapshot.dropped_requests +=
986
+ load_report.drop_stats->GetSnapshotAndReset();
987
+ GRPC_TRACE_LOG(xds_client, INFO)
988
+ << "[lrs_client " << this << "] cluster=" << cluster_key.first
989
+ << " eds_service_name=" << cluster_key.second
990
+ << " drop_stats=" << load_report.drop_stats;
991
+ }
992
+ // Aggregate locality stats.
993
+ for (auto it = load_report.locality_stats.begin();
994
+ it != load_report.locality_stats.end();) {
995
+ const RefCountedPtr<XdsLocalityName>& locality_name = it->first;
996
+ auto& locality_state = it->second;
997
+ ClusterLocalityStats::Snapshot& locality_snapshot =
998
+ snapshot.locality_stats[locality_name];
999
+ locality_snapshot = std::move(locality_state.deleted_locality_stats);
1000
+ for (const auto& p : locality_state.propagation_stats) {
1001
+ ClusterLocalityStats* locality_stats = p.second;
1002
+ if (locality_stats != nullptr) {
1003
+ locality_snapshot += locality_stats->GetSnapshotAndReset();
1004
+ GRPC_TRACE_LOG(xds_client, INFO)
1005
+ << "[lrs_client " << this
1006
+ << "] cluster=" << cluster_key.first.c_str()
1007
+ << " eds_service_name=" << cluster_key.second.c_str()
1008
+ << " locality=" << locality_name->human_readable_string().c_str()
1009
+ << " propagation=" << p.first->AsString()
1010
+ << " locality_stats=" << locality_stats;
1011
+ }
1012
+ }
1013
+ // If the only thing left in this entry was final snapshots from
1014
+ // deleted locality stats objects, remove the entry.
1015
+ if (locality_state.propagation_stats.empty()) {
1016
+ it = load_report.locality_stats.erase(it);
1017
+ } else {
1018
+ ++it;
1019
+ }
1020
+ }
1021
+ // Compute load report interval.
1022
+ const Timestamp now = Timestamp::Now();
1023
+ snapshot.load_report_interval = now - load_report.last_report_time;
1024
+ load_report.last_report_time = now;
1025
+ // Record snapshot.
1026
+ if (record_stats) {
1027
+ snapshot_map[cluster_key] = std::move(snapshot);
1028
+ }
1029
+ // If the only thing left in this entry was final snapshots from
1030
+ // deleted stats objects, remove the entry.
1031
+ if (load_report.locality_stats.empty() &&
1032
+ load_report.drop_stats == nullptr) {
1033
+ load_report_it = load_report_map.erase(load_report_it);
1034
+ } else {
1035
+ ++load_report_it;
1036
+ }
1037
+ }
1038
+ return snapshot_map;
1039
+ }
1040
+
1041
+ namespace {
1042
+
1043
+ struct LrsApiContext {
1044
+ LrsClient* client;
1045
+ upb_DefPool* def_pool;
1046
+ upb_Arena* arena;
1047
+ };
1048
+
1049
+ void MaybeLogLrsRequest(
1050
+ const LrsApiContext& context,
1051
+ const envoy_service_load_stats_v3_LoadStatsRequest* request) {
1052
+ if (GRPC_TRACE_FLAG_ENABLED(xds_client) && ABSL_VLOG_IS_ON(2)) {
1053
+ const upb_MessageDef* msg_type =
1054
+ envoy_service_load_stats_v3_LoadStatsRequest_getmsgdef(
1055
+ context.def_pool);
1056
+ char buf[10240];
1057
+ upb_TextEncode(reinterpret_cast<const upb_Message*>(request), msg_type,
1058
+ nullptr, 0, buf, sizeof(buf));
1059
+ VLOG(2) << "[lrs_client " << context.client
1060
+ << "] constructed LRS request: " << buf;
1061
+ }
1062
+ }
1063
+
1064
+ std::string SerializeLrsRequest(
1065
+ const LrsApiContext& context,
1066
+ const envoy_service_load_stats_v3_LoadStatsRequest* request) {
1067
+ size_t output_length;
1068
+ char* output = envoy_service_load_stats_v3_LoadStatsRequest_serialize(
1069
+ request, context.arena, &output_length);
1070
+ return std::string(output, output_length);
1071
+ }
1072
+
1073
+ } // namespace
1074
+
1075
+ std::string LrsClient::CreateLrsInitialRequest() {
1076
+ upb::Arena arena;
1077
+ const LrsApiContext context = {this, def_pool_.ptr(), arena.ptr()};
1078
+ // Create a request.
1079
+ envoy_service_load_stats_v3_LoadStatsRequest* request =
1080
+ envoy_service_load_stats_v3_LoadStatsRequest_new(arena.ptr());
1081
+ // Populate node.
1082
+ envoy_config_core_v3_Node* node_msg =
1083
+ envoy_service_load_stats_v3_LoadStatsRequest_mutable_node(request,
1084
+ arena.ptr());
1085
+ PopulateXdsNode(bootstrap_->node(), user_agent_name_, user_agent_version_,
1086
+ node_msg, arena.ptr());
1087
+ envoy_config_core_v3_Node_add_client_features(
1088
+ node_msg,
1089
+ upb_StringView_FromString("envoy.lrs.supports_send_all_clusters"),
1090
+ arena.ptr());
1091
+ MaybeLogLrsRequest(context, request);
1092
+ return SerializeLrsRequest(context, request);
1093
+ }
1094
+
1095
+ namespace {
1096
+
1097
+ void MaybeAddUnnamedMetric(
1098
+ const LrsApiContext& context,
1099
+ const LrsClient::ClusterLocalityStats::BackendMetric& backend_metric,
1100
+ envoy_config_endpoint_v3_UnnamedEndpointLoadMetricStats* (*add_field)(
1101
+ envoy_config_endpoint_v3_UpstreamLocalityStats*, upb_Arena*),
1102
+ envoy_config_endpoint_v3_UpstreamLocalityStats* output) {
1103
+ if (backend_metric.IsZero()) return;
1104
+ auto* metric_proto = add_field(output, context.arena);
1105
+ envoy_config_endpoint_v3_UnnamedEndpointLoadMetricStats_set_num_requests_finished_with_metric(
1106
+ metric_proto, backend_metric.num_requests_finished_with_metric);
1107
+ envoy_config_endpoint_v3_UnnamedEndpointLoadMetricStats_set_total_metric_value(
1108
+ metric_proto, backend_metric.total_metric_value);
1109
+ }
1110
+
1111
+ void LocalityStatsPopulate(
1112
+ const LrsApiContext& context,
1113
+ envoy_config_endpoint_v3_UpstreamLocalityStats* output,
1114
+ const XdsLocalityName& locality_name,
1115
+ const LrsClient::ClusterLocalityStats::Snapshot& snapshot) {
1116
+ // Set locality.
1117
+ envoy_config_core_v3_Locality* locality =
1118
+ envoy_config_endpoint_v3_UpstreamLocalityStats_mutable_locality(
1119
+ output, context.arena);
1120
+ if (!locality_name.region().empty()) {
1121
+ envoy_config_core_v3_Locality_set_region(
1122
+ locality, StdStringToUpbString(locality_name.region()));
1123
+ }
1124
+ if (!locality_name.zone().empty()) {
1125
+ envoy_config_core_v3_Locality_set_zone(
1126
+ locality, StdStringToUpbString(locality_name.zone()));
1127
+ }
1128
+ if (!locality_name.sub_zone().empty()) {
1129
+ envoy_config_core_v3_Locality_set_sub_zone(
1130
+ locality, StdStringToUpbString(locality_name.sub_zone()));
1131
+ }
1132
+ // Set total counts.
1133
+ envoy_config_endpoint_v3_UpstreamLocalityStats_set_total_successful_requests(
1134
+ output, snapshot.total_successful_requests);
1135
+ envoy_config_endpoint_v3_UpstreamLocalityStats_set_total_requests_in_progress(
1136
+ output, snapshot.total_requests_in_progress);
1137
+ envoy_config_endpoint_v3_UpstreamLocalityStats_set_total_error_requests(
1138
+ output, snapshot.total_error_requests);
1139
+ envoy_config_endpoint_v3_UpstreamLocalityStats_set_total_issued_requests(
1140
+ output, snapshot.total_issued_requests);
1141
+ // Add backend metrics.
1142
+ MaybeAddUnnamedMetric(
1143
+ context, snapshot.cpu_utilization,
1144
+ envoy_config_endpoint_v3_UpstreamLocalityStats_mutable_cpu_utilization,
1145
+ output);
1146
+ MaybeAddUnnamedMetric(
1147
+ context, snapshot.mem_utilization,
1148
+ envoy_config_endpoint_v3_UpstreamLocalityStats_mutable_mem_utilization,
1149
+ output);
1150
+ MaybeAddUnnamedMetric(
1151
+ context, snapshot.application_utilization,
1152
+ envoy_config_endpoint_v3_UpstreamLocalityStats_mutable_application_utilization,
1153
+ output);
1154
+ for (const auto& p : snapshot.backend_metrics) {
1155
+ const std::string& metric_name = p.first;
1156
+ const LrsClient::ClusterLocalityStats::BackendMetric& metric_value =
1157
+ p.second;
1158
+ envoy_config_endpoint_v3_EndpointLoadMetricStats* load_metric =
1159
+ envoy_config_endpoint_v3_UpstreamLocalityStats_add_load_metric_stats(
1160
+ output, context.arena);
1161
+ envoy_config_endpoint_v3_EndpointLoadMetricStats_set_metric_name(
1162
+ load_metric, StdStringToUpbString(metric_name));
1163
+ envoy_config_endpoint_v3_EndpointLoadMetricStats_set_num_requests_finished_with_metric(
1164
+ load_metric, metric_value.num_requests_finished_with_metric);
1165
+ envoy_config_endpoint_v3_EndpointLoadMetricStats_set_total_metric_value(
1166
+ load_metric, metric_value.total_metric_value);
1167
+ }
1168
+ }
1169
+
1170
+ } // namespace
1171
+
1172
+ std::string LrsClient::CreateLrsRequest(
1173
+ ClusterLoadReportMap cluster_load_report_map) {
1174
+ upb::Arena arena;
1175
+ const LrsApiContext context = {this, def_pool_.ptr(), arena.ptr()};
1176
+ // Create a request.
1177
+ envoy_service_load_stats_v3_LoadStatsRequest* request =
1178
+ envoy_service_load_stats_v3_LoadStatsRequest_new(arena.ptr());
1179
+ for (auto& p : cluster_load_report_map) {
1180
+ const std::string& cluster_name = p.first.first;
1181
+ const std::string& eds_service_name = p.first.second;
1182
+ const ClusterLoadReport& load_report = p.second;
1183
+ // Add cluster stats.
1184
+ envoy_config_endpoint_v3_ClusterStats* cluster_stats =
1185
+ envoy_service_load_stats_v3_LoadStatsRequest_add_cluster_stats(
1186
+ request, arena.ptr());
1187
+ // Set the cluster name.
1188
+ envoy_config_endpoint_v3_ClusterStats_set_cluster_name(
1189
+ cluster_stats, StdStringToUpbString(cluster_name));
1190
+ // Set EDS service name, if non-empty.
1191
+ if (!eds_service_name.empty()) {
1192
+ envoy_config_endpoint_v3_ClusterStats_set_cluster_service_name(
1193
+ cluster_stats, StdStringToUpbString(eds_service_name));
1194
+ }
1195
+ // Add locality stats.
1196
+ for (const auto& p : load_report.locality_stats) {
1197
+ const XdsLocalityName& locality_name = *p.first;
1198
+ const auto& snapshot = p.second;
1199
+ envoy_config_endpoint_v3_UpstreamLocalityStats* locality_stats =
1200
+ envoy_config_endpoint_v3_ClusterStats_add_upstream_locality_stats(
1201
+ cluster_stats, arena.ptr());
1202
+ LocalityStatsPopulate(context, locality_stats, locality_name, snapshot);
1203
+ }
1204
+ // Add dropped requests.
1205
+ uint64_t total_dropped_requests = 0;
1206
+ for (const auto& p : load_report.dropped_requests.categorized_drops) {
1207
+ const std::string& category = p.first;
1208
+ const uint64_t count = p.second;
1209
+ envoy_config_endpoint_v3_ClusterStats_DroppedRequests* dropped_requests =
1210
+ envoy_config_endpoint_v3_ClusterStats_add_dropped_requests(
1211
+ cluster_stats, arena.ptr());
1212
+ envoy_config_endpoint_v3_ClusterStats_DroppedRequests_set_category(
1213
+ dropped_requests, StdStringToUpbString(category));
1214
+ envoy_config_endpoint_v3_ClusterStats_DroppedRequests_set_dropped_count(
1215
+ dropped_requests, count);
1216
+ total_dropped_requests += count;
1217
+ }
1218
+ total_dropped_requests += load_report.dropped_requests.uncategorized_drops;
1219
+ // Set total dropped requests.
1220
+ envoy_config_endpoint_v3_ClusterStats_set_total_dropped_requests(
1221
+ cluster_stats, total_dropped_requests);
1222
+ // Set real load report interval.
1223
+ gpr_timespec timespec = load_report.load_report_interval.as_timespec();
1224
+ google_protobuf_Duration* load_report_interval =
1225
+ envoy_config_endpoint_v3_ClusterStats_mutable_load_report_interval(
1226
+ cluster_stats, arena.ptr());
1227
+ google_protobuf_Duration_set_seconds(load_report_interval, timespec.tv_sec);
1228
+ google_protobuf_Duration_set_nanos(load_report_interval, timespec.tv_nsec);
1229
+ }
1230
+ MaybeLogLrsRequest(context, request);
1231
+ return SerializeLrsRequest(context, request);
1232
+ }
1233
+
1234
+ namespace {
1235
+
1236
+ void MaybeLogLrsResponse(
1237
+ const LrsApiContext& context,
1238
+ const envoy_service_load_stats_v3_LoadStatsResponse* response) {
1239
+ if (GRPC_TRACE_FLAG_ENABLED(xds_client) && ABSL_VLOG_IS_ON(2)) {
1240
+ const upb_MessageDef* msg_type =
1241
+ envoy_service_load_stats_v3_LoadStatsResponse_getmsgdef(
1242
+ context.def_pool);
1243
+ char buf[10240];
1244
+ upb_TextEncode(reinterpret_cast<const upb_Message*>(response), msg_type,
1245
+ nullptr, 0, buf, sizeof(buf));
1246
+ VLOG(2) << "[lrs_client " << context.client
1247
+ << "] received LRS response: " << buf;
1248
+ }
1249
+ }
1250
+
1251
+ } // namespace
1252
+
1253
+ absl::Status LrsClient::ParseLrsResponse(absl::string_view encoded_response,
1254
+ bool* send_all_clusters,
1255
+ std::set<std::string>* cluster_names,
1256
+ Duration* load_reporting_interval) {
1257
+ upb::Arena arena;
1258
+ // Decode the response.
1259
+ const envoy_service_load_stats_v3_LoadStatsResponse* decoded_response =
1260
+ envoy_service_load_stats_v3_LoadStatsResponse_parse(
1261
+ encoded_response.data(), encoded_response.size(), arena.ptr());
1262
+ // Parse the response.
1263
+ if (decoded_response == nullptr) {
1264
+ return absl::UnavailableError("Can't decode response.");
1265
+ }
1266
+ const LrsApiContext context = {this, def_pool_.ptr(), arena.ptr()};
1267
+ MaybeLogLrsResponse(context, decoded_response);
1268
+ // Check send_all_clusters.
1269
+ if (envoy_service_load_stats_v3_LoadStatsResponse_send_all_clusters(
1270
+ decoded_response)) {
1271
+ *send_all_clusters = true;
1272
+ } else {
1273
+ // Store the cluster names.
1274
+ size_t size;
1275
+ const upb_StringView* clusters =
1276
+ envoy_service_load_stats_v3_LoadStatsResponse_clusters(decoded_response,
1277
+ &size);
1278
+ for (size_t i = 0; i < size; ++i) {
1279
+ cluster_names->emplace(UpbStringToStdString(clusters[i]));
1280
+ }
1281
+ }
1282
+ // Get the load report interval.
1283
+ const google_protobuf_Duration* load_reporting_interval_duration =
1284
+ envoy_service_load_stats_v3_LoadStatsResponse_load_reporting_interval(
1285
+ decoded_response);
1286
+ *load_reporting_interval = Duration::FromSecondsAndNanoseconds(
1287
+ google_protobuf_Duration_seconds(load_reporting_interval_duration),
1288
+ google_protobuf_Duration_nanos(load_reporting_interval_duration));
1289
+ return absl::OkStatus();
1290
+ }
1291
+
1292
+ } // namespace grpc_core