grpc 1.67.0 → 1.69.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (2045) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +58 -46
  3. data/include/grpc/compression.h +1 -2
  4. data/include/grpc/credentials.h +1 -2
  5. data/include/grpc/event_engine/endpoint_config.h +2 -2
  6. data/include/grpc/event_engine/event_engine.h +12 -9
  7. data/include/grpc/event_engine/extensible.h +2 -2
  8. data/include/grpc/event_engine/internal/memory_allocator_impl.h +4 -4
  9. data/include/grpc/event_engine/memory_allocator.h +3 -4
  10. data/include/grpc/event_engine/memory_request.h +1 -2
  11. data/include/grpc/event_engine/slice.h +3 -4
  12. data/include/grpc/event_engine/slice_buffer.h +6 -7
  13. data/include/grpc/grpc.h +1 -2
  14. data/include/grpc/grpc_audit_logging.h +3 -3
  15. data/include/grpc/grpc_crl_provider.h +4 -4
  16. data/include/grpc/grpc_posix.h +1 -2
  17. data/include/grpc/grpc_security.h +1 -2
  18. data/include/grpc/impl/call.h +2 -2
  19. data/include/grpc/impl/channel_arg_names.h +2 -0
  20. data/include/grpc/impl/grpc_types.h +1 -2
  21. data/include/grpc/impl/slice_type.h +1 -2
  22. data/include/grpc/passive_listener.h +2 -2
  23. data/include/grpc/support/alloc.h +1 -2
  24. data/include/grpc/support/json.h +1 -2
  25. data/include/grpc/support/log.h +1 -2
  26. data/include/grpc/support/metrics.h +7 -3
  27. data/include/grpc/support/port_platform.h +6 -1
  28. data/include/grpc/support/sync_posix.h +1 -2
  29. data/include/grpc/support/time.h +1 -2
  30. data/src/core/channelz/channel_trace.cc +5 -6
  31. data/src/core/channelz/channel_trace.h +5 -7
  32. data/src/core/channelz/channelz.cc +5 -6
  33. data/src/core/channelz/channelz.h +8 -10
  34. data/src/core/channelz/channelz_registry.cc +6 -7
  35. data/src/core/channelz/channelz_registry.h +4 -5
  36. data/src/core/client_channel/backup_poller.cc +21 -11
  37. data/src/core/client_channel/client_channel.cc +24 -20
  38. data/src/core/client_channel/client_channel.h +4 -2
  39. data/src/core/client_channel/client_channel_factory.cc +2 -2
  40. data/src/core/client_channel/client_channel_factory.h +1 -2
  41. data/src/core/client_channel/client_channel_filter.cc +27 -24
  42. data/src/core/client_channel/client_channel_filter.h +11 -11
  43. data/src/core/client_channel/client_channel_internal.h +2 -3
  44. data/src/core/client_channel/client_channel_plugin.cc +2 -4
  45. data/src/core/client_channel/client_channel_service_config.cc +2 -3
  46. data/src/core/client_channel/client_channel_service_config.h +4 -6
  47. data/src/core/client_channel/config_selector.h +4 -7
  48. data/src/core/client_channel/connector.h +3 -3
  49. data/src/core/client_channel/direct_channel.cc +3 -3
  50. data/src/core/client_channel/dynamic_filters.cc +10 -8
  51. data/src/core/client_channel/dynamic_filters.h +8 -7
  52. data/src/core/client_channel/global_subchannel_pool.cc +2 -2
  53. data/src/core/client_channel/global_subchannel_pool.h +2 -3
  54. data/src/core/client_channel/lb_metadata.h +2 -3
  55. data/src/core/client_channel/load_balanced_call_destination.cc +2 -3
  56. data/src/core/client_channel/load_balanced_call_destination.h +0 -1
  57. data/src/core/client_channel/local_subchannel_pool.cc +2 -3
  58. data/src/core/client_channel/local_subchannel_pool.h +1 -1
  59. data/src/core/client_channel/retry_filter.cc +5 -7
  60. data/src/core/client_channel/retry_filter.h +4 -7
  61. data/src/core/client_channel/retry_filter_legacy_call_data.cc +12 -12
  62. data/src/core/client_channel/retry_filter_legacy_call_data.h +11 -12
  63. data/src/core/client_channel/retry_service_config.cc +6 -8
  64. data/src/core/client_channel/retry_service_config.h +3 -5
  65. data/src/core/client_channel/retry_throttle.cc +3 -4
  66. data/src/core/client_channel/retry_throttle.h +4 -7
  67. data/src/core/client_channel/subchannel.cc +12 -15
  68. data/src/core/client_channel/subchannel.h +17 -16
  69. data/src/core/client_channel/subchannel_interface_internal.h +1 -1
  70. data/src/core/client_channel/subchannel_pool_interface.cc +1 -3
  71. data/src/core/client_channel/subchannel_pool_interface.h +2 -3
  72. data/src/core/client_channel/subchannel_stream_client.cc +6 -9
  73. data/src/core/client_channel/subchannel_stream_client.h +8 -10
  74. data/src/core/{lib/config → config}/config_vars.cc +4 -5
  75. data/src/core/{lib/config → config}/config_vars.h +4 -5
  76. data/src/core/{lib/config → config}/config_vars_non_generated.cc +3 -3
  77. data/src/core/{lib/config → config}/core_configuration.cc +4 -4
  78. data/src/core/{lib/config → config}/core_configuration.h +5 -6
  79. data/src/core/{lib/config → config}/load_config.cc +3 -5
  80. data/src/core/{lib/config → config}/load_config.h +4 -5
  81. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +9 -9
  82. data/src/core/ext/filters/backend_metrics/backend_metric_filter.h +0 -1
  83. data/src/core/ext/filters/census/grpc_context.cc +1 -2
  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 +16 -18
  87. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.h +6 -8
  88. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +10 -7
  89. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +1 -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 +4 -7
  92. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.cc +55 -17
  93. data/src/core/ext/filters/gcp_authentication/gcp_authentication_filter.h +28 -13
  94. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.cc +2 -3
  95. data/src/core/ext/filters/gcp_authentication/gcp_authentication_service_config_parser.h +2 -3
  96. data/src/core/ext/filters/http/client/http_client_filter.cc +12 -7
  97. data/src/core/ext/filters/http/client/http_client_filter.h +0 -1
  98. data/src/core/ext/filters/http/client_authority_filter.cc +7 -6
  99. data/src/core/ext/filters/http/client_authority_filter.h +0 -1
  100. data/src/core/ext/filters/http/http_filters_plugin.cc +1 -2
  101. data/src/core/ext/filters/http/message_compress/compression_filter.cc +24 -10
  102. data/src/core/ext/filters/http/message_compress/compression_filter.h +1 -4
  103. data/src/core/ext/filters/http/server/http_server_filter.cc +11 -6
  104. data/src/core/ext/filters/http/server/http_server_filter.h +0 -1
  105. data/src/core/ext/filters/message_size/message_size_filter.cc +13 -7
  106. data/src/core/ext/filters/message_size/message_size_filter.h +2 -4
  107. data/src/core/ext/filters/rbac/rbac_filter.cc +6 -6
  108. data/src/core/ext/filters/rbac/rbac_filter.h +0 -2
  109. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +14 -8
  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 +11 -6
  112. data/src/core/ext/filters/stateful_session/stateful_session_filter.h +2 -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 +3 -5
  115. data/src/core/ext/transport/chttp2/alpn/alpn.cc +1 -2
  116. data/src/core/ext/transport/chttp2/alpn/alpn.h +1 -2
  117. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +20 -24
  118. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +4 -5
  119. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +151 -90
  120. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -2
  121. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +6 -6
  122. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -3
  123. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +4 -6
  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 +152 -95
  128. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +5 -6
  129. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +1 -2
  130. data/src/core/ext/transport/chttp2/transport/decode_huff.h +4 -4
  131. data/src/core/ext/transport/chttp2/transport/flow_control.cc +3 -5
  132. data/src/core/ext/transport/chttp2/transport/flow_control.h +2 -4
  133. data/src/core/ext/transport/chttp2/transport/frame.cc +22 -4
  134. data/src/core/ext/transport/chttp2/transport/frame.h +13 -4
  135. data/src/core/ext/transport/chttp2/transport/frame_data.cc +17 -13
  136. data/src/core/ext/transport/chttp2/transport/frame_data.h +2 -4
  137. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +3 -5
  138. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -2
  139. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +2 -4
  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 +4 -5
  142. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +1 -2
  143. data/src/core/ext/transport/chttp2/transport/frame_security.cc +82 -0
  144. data/src/core/ext/transport/chttp2/transport/frame_security.h +44 -0
  145. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +19 -5
  146. data/src/core/ext/transport/chttp2/transport/frame_settings.h +3 -4
  147. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +21 -3
  148. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +1 -2
  149. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +2 -2
  150. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +10 -11
  151. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +6 -8
  152. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +2 -2
  153. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +4 -5
  154. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +2 -4
  155. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +4 -6
  156. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +4 -6
  157. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +3 -5
  158. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +1 -3
  159. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +2 -4
  160. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +10 -2
  161. data/src/core/ext/transport/chttp2/transport/http2_settings.h +10 -4
  162. data/src/core/ext/transport/chttp2/transport/internal.h +37 -99
  163. data/src/core/ext/transport/chttp2/transport/legacy_frame.h +1 -0
  164. data/src/core/ext/transport/chttp2/transport/parsing.cc +44 -9
  165. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.cc +3 -3
  166. data/src/core/ext/transport/chttp2/transport/ping_abuse_policy.h +3 -3
  167. data/src/core/ext/transport/chttp2/transport/ping_callbacks.cc +2 -2
  168. data/src/core/ext/transport/chttp2/transport/ping_callbacks.h +3 -5
  169. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +4 -5
  170. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +2 -4
  171. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +4 -3
  172. data/src/core/ext/transport/chttp2/transport/stream_lists.h +65 -0
  173. data/src/core/ext/transport/chttp2/transport/varint.cc +2 -2
  174. data/src/core/ext/transport/chttp2/transport/varint.h +1 -2
  175. data/src/core/ext/transport/chttp2/transport/write_size_policy.cc +2 -2
  176. data/src/core/ext/transport/chttp2/transport/write_size_policy.h +3 -4
  177. data/src/core/ext/transport/chttp2/transport/writing.cc +11 -11
  178. data/src/core/ext/transport/inproc/inproc_transport.cc +6 -7
  179. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +12 -14
  180. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +35 -4
  181. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.c +25 -18
  182. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb_minitable.h +10 -4
  183. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb.h +36 -4
  184. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.c +24 -18
  185. data/src/core/ext/upb-gen/envoy/admin/v3/clusters.upb_minitable.h +9 -4
  186. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb.h +39 -4
  187. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.c +29 -22
  188. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump.upb_minitable.h +10 -4
  189. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb.h +137 -4
  190. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.c +105 -84
  191. data/src/core/ext/upb-gen/envoy/admin/v3/config_dump_shared.upb_minitable.h +24 -4
  192. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb.h +10 -4
  193. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.c +8 -4
  194. data/src/core/ext/upb-gen/envoy/admin/v3/init_dump.upb_minitable.h +7 -4
  195. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb.h +17 -4
  196. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.c +12 -8
  197. data/src/core/ext/upb-gen/envoy/admin/v3/listeners.upb_minitable.h +7 -4
  198. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb.h +5 -4
  199. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.c +4 -1
  200. data/src/core/ext/upb-gen/envoy/admin/v3/memory.upb_minitable.h +6 -4
  201. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb.h +5 -4
  202. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.c +4 -1
  203. data/src/core/ext/upb-gen/envoy/admin/v3/metrics.upb_minitable.h +6 -4
  204. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb.h +5 -4
  205. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.c +4 -1
  206. data/src/core/ext/upb-gen/envoy/admin/v3/mutex_stats.upb_minitable.h +6 -4
  207. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb.h +19 -4
  208. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.c +16 -12
  209. data/src/core/ext/upb-gen/envoy/admin/v3/server_info.upb_minitable.h +7 -4
  210. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb.h +7 -4
  211. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.c +7 -4
  212. data/src/core/ext/upb-gen/envoy/admin/v3/tap.upb_minitable.h +6 -4
  213. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb.h +5 -4
  214. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.c +7 -1
  215. data/src/core/ext/upb-gen/envoy/annotations/deprecation.upb_minitable.h +5 -4
  216. data/src/core/ext/upb-gen/envoy/annotations/resource.upb.h +7 -6
  217. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.c +10 -6
  218. data/src/core/ext/upb-gen/envoy/annotations/resource.upb_minitable.h +6 -4
  219. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +61 -4
  220. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.c +66 -48
  221. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb_minitable.h +21 -4
  222. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +183 -4
  223. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.c +131 -106
  224. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb_minitable.h +28 -4
  225. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb.h +31 -4
  226. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.c +22 -17
  227. data/src/core/ext/upb-gen/envoy/config/cluster/v3/circuit_breaker.upb_minitable.h +8 -4
  228. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +185 -4
  229. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.c +149 -122
  230. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb_minitable.h +30 -4
  231. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb.h +9 -4
  232. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.c +8 -5
  233. data/src/core/ext/upb-gen/envoy/config/cluster/v3/filter.upb_minitable.h +6 -4
  234. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb.h +56 -4
  235. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.c +30 -27
  236. data/src/core/ext/upb-gen/envoy/config/cluster/v3/outlier_detection.upb_minitable.h +6 -4
  237. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +96 -4
  238. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.c +80 -63
  239. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb_minitable.h +20 -4
  240. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +44 -4
  241. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.c +36 -26
  242. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb_minitable.h +13 -4
  243. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb.h +9 -4
  244. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.c +8 -5
  245. data/src/core/ext/upb-gen/envoy/config/core/v3/backoff.upb_minitable.h +6 -4
  246. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +109 -4
  247. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.c +108 -77
  248. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb_minitable.h +34 -4
  249. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +46 -4
  250. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.c +36 -27
  251. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb_minitable.h +12 -4
  252. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +7 -4
  253. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.c +7 -4
  254. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb_minitable.h +6 -4
  255. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb.h +7 -4
  256. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.c +7 -4
  257. data/src/core/ext/upb-gen/envoy/config/core/v3/extension.upb_minitable.h +6 -4
  258. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb.h +10 -4
  259. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.c +8 -4
  260. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_method_list.upb_minitable.h +7 -4
  261. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +71 -4
  262. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +61 -45
  263. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.h +19 -4
  264. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +92 -4
  265. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.c +55 -44
  266. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb_minitable.h +14 -4
  267. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb.h +12 -4
  268. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.c +8 -5
  269. data/src/core/ext/upb-gen/envoy/config/core/v3/http_service.upb_minitable.h +6 -4
  270. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +7 -4
  271. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.c +7 -4
  272. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb_minitable.h +6 -4
  273. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +99 -4
  274. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.c +85 -67
  275. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb_minitable.h +21 -4
  276. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb.h +7 -4
  277. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.c +8 -4
  278. data/src/core/ext/upb-gen/envoy/config/core/v3/proxy_protocol.upb_minitable.h +7 -4
  279. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb.h +12 -4
  280. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.c +9 -5
  281. data/src/core/ext/upb-gen/envoy/config/core/v3/resolver.upb_minitable.h +7 -4
  282. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +10 -4
  283. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.c +8 -4
  284. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb_minitable.h +7 -4
  285. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +16 -4
  286. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.c +11 -7
  287. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb_minitable.h +7 -4
  288. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb.h +9 -4
  289. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.c +8 -5
  290. data/src/core/ext/upb-gen/envoy/config/core/v3/udp_socket_config.upb_minitable.h +6 -4
  291. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +35 -4
  292. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.c +23 -17
  293. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb_minitable.h +9 -4
  294. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +48 -4
  295. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.c +41 -32
  296. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb_minitable.h +12 -4
  297. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb.h +44 -4
  298. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.c +27 -19
  299. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/load_report.upb_minitable.h +11 -4
  300. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb.h +7 -4
  301. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.c +7 -4
  302. data/src/core/ext/upb-gen/envoy/config/listener/v3/api_listener.upb_minitable.h +6 -4
  303. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +83 -4
  304. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.c +53 -41
  305. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb_minitable.h +15 -4
  306. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +66 -4
  307. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.c +47 -38
  308. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb_minitable.h +12 -4
  309. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb.h +27 -4
  310. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.c +17 -14
  311. data/src/core/ext/upb-gen/envoy/config/listener/v3/quic_config.upb_minitable.h +6 -4
  312. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb.h +11 -4
  313. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.c +10 -6
  314. data/src/core/ext/upb-gen/envoy/config/listener/v3/udp_listener_config.upb_minitable.h +7 -4
  315. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb.h +9 -4
  316. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.c +8 -5
  317. data/src/core/ext/upb-gen/envoy/config/metrics/v3/metrics_service.upb_minitable.h +6 -4
  318. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +33 -4
  319. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.c +34 -24
  320. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb_minitable.h +13 -4
  321. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +51 -4
  322. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.c +41 -29
  323. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb_minitable.h +15 -4
  324. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +96 -4
  325. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.c +68 -55
  326. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb_minitable.h +16 -4
  327. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +52 -4
  328. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.c +24 -19
  329. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb_minitable.h +8 -4
  330. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +435 -4
  331. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.c +306 -246
  332. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb_minitable.h +63 -4
  333. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +14 -4
  334. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.c +13 -8
  335. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb_minitable.h +8 -4
  336. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +69 -4
  337. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.c +59 -45
  338. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb_minitable.h +17 -4
  339. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb.h +9 -4
  340. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.c +11 -7
  341. data/src/core/ext/upb-gen/envoy/config/trace/v3/datadog.upb_minitable.h +7 -4
  342. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb.h +7 -4
  343. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.c +7 -4
  344. data/src/core/ext/upb-gen/envoy/config/trace/v3/dynamic_ot.upb_minitable.h +6 -4
  345. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +9 -4
  346. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.c +11 -7
  347. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb_minitable.h +7 -4
  348. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb.h +7 -4
  349. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.c +7 -4
  350. data/src/core/ext/upb-gen/envoy/config/trace/v3/lightstep.upb_minitable.h +6 -4
  351. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb.h +11 -4
  352. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.c +9 -6
  353. data/src/core/ext/upb-gen/envoy/config/trace/v3/opencensus.upb_minitable.h +6 -4
  354. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb.h +16 -4
  355. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.c +10 -7
  356. data/src/core/ext/upb-gen/envoy/config/trace/v3/opentelemetry.upb_minitable.h +6 -4
  357. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb.h +7 -4
  358. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.c +7 -4
  359. data/src/core/ext/upb-gen/envoy/config/trace/v3/service.upb_minitable.h +6 -4
  360. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +11 -4
  361. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.c +12 -8
  362. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb_minitable.h +7 -4
  363. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb.h +5 -4
  364. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.c +3 -1
  365. data/src/core/ext/upb-gen/envoy/config/trace/v3/trace.upb_minitable.h +5 -4
  366. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb.h +13 -4
  367. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.c +13 -9
  368. data/src/core/ext/upb-gen/envoy/config/trace/v3/xray.upb_minitable.h +7 -4
  369. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb.h +7 -4
  370. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.c +7 -4
  371. data/src/core/ext/upb-gen/envoy/config/trace/v3/zipkin.upb_minitable.h +6 -4
  372. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +102 -4
  373. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.c +72 -54
  374. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb_minitable.h +21 -4
  375. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +5 -4
  376. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.c +4 -1
  377. data/src/core/ext/upb-gen/envoy/extensions/clusters/aggregate/v3/cluster.upb_minitable.h +6 -4
  378. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +17 -4
  379. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.c +18 -11
  380. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb_minitable.h +10 -4
  381. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +24 -4
  382. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.c +18 -13
  383. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb_minitable.h +8 -4
  384. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb.h +17 -4
  385. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.c +17 -11
  386. data/src/core/ext/upb-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upb_minitable.h +9 -4
  387. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +15 -4
  388. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.c +14 -10
  389. data/src/core/ext/upb-gen/envoy/extensions/filters/http/rbac/v3/rbac.upb_minitable.h +7 -4
  390. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb.h +21 -4
  391. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.c +14 -10
  392. data/src/core/ext/upb-gen/envoy/extensions/filters/http/router/v3/router.upb_minitable.h +7 -4
  393. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +9 -4
  394. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.c +11 -7
  395. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb_minitable.h +7 -4
  396. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +181 -4
  397. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.c +132 -109
  398. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb_minitable.h +26 -4
  399. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +7 -4
  400. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.c +7 -4
  401. data/src/core/ext/upb-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb_minitable.h +6 -4
  402. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +17 -4
  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.c +12 -9
  404. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb_minitable.h +6 -4
  405. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +21 -4
  406. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.c +24 -17
  407. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb_minitable.h +10 -4
  408. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb.h +5 -4
  409. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.c +4 -1
  410. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/pick_first/v3/pick_first.upb_minitable.h +6 -4
  411. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +15 -4
  412. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.c +11 -8
  413. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb_minitable.h +6 -4
  414. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +7 -4
  415. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.c +7 -4
  416. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb_minitable.h +6 -4
  417. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb.h +106 -0
  418. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.c +52 -0
  419. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upb_minitable.h +32 -0
  420. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +5 -4
  421. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.c +3 -1
  422. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/cert.upb_minitable.h +5 -4
  423. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +59 -4
  424. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.c +42 -32
  425. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb_minitable.h +13 -4
  426. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +17 -4
  427. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.c +18 -13
  428. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb_minitable.h +8 -4
  429. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +77 -4
  430. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.c +52 -43
  431. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb_minitable.h +12 -4
  432. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +12 -4
  433. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.c +11 -7
  434. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb_minitable.h +7 -4
  435. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +42 -4
  436. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.c +32 -26
  437. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb_minitable.h +9 -4
  438. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb.h +5 -4
  439. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.c +4 -1
  440. data/src/core/ext/upb-gen/envoy/service/discovery/v3/ads.upb_minitable.h +6 -4
  441. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +86 -4
  442. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.c +63 -47
  443. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb_minitable.h +19 -4
  444. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb.h +14 -4
  445. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.c +12 -8
  446. data/src/core/ext/upb-gen/envoy/service/load_stats/v3/lrs.upb_minitable.h +7 -4
  447. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +45 -4
  448. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.c +32 -25
  449. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb_minitable.h +10 -4
  450. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb.h +7 -4
  451. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.c +7 -4
  452. data/src/core/ext/upb-gen/envoy/type/http/v3/cookie.upb_minitable.h +6 -4
  453. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +14 -4
  454. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.c +14 -8
  455. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb_minitable.h +9 -4
  456. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +7 -4
  457. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.c +7 -4
  458. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb_minitable.h +6 -4
  459. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb.h +5 -4
  460. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.c +8 -1
  461. data/src/core/ext/upb-gen/envoy/type/matcher/v3/http_inputs.upb_minitable.h +10 -4
  462. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +12 -4
  463. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.c +9 -5
  464. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb_minitable.h +7 -4
  465. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb.h +12 -4
  466. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.c +8 -5
  467. data/src/core/ext/upb-gen/envoy/type/matcher/v3/node.upb_minitable.h +6 -4
  468. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +7 -4
  469. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.c +7 -4
  470. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb_minitable.h +6 -4
  471. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +7 -4
  472. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.c +7 -4
  473. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb_minitable.h +6 -4
  474. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +11 -4
  475. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.c +15 -10
  476. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb_minitable.h +8 -4
  477. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb.h +5 -4
  478. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.c +5 -1
  479. data/src/core/ext/upb-gen/envoy/type/matcher/v3/status_code_input.upb_minitable.h +7 -4
  480. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +14 -4
  481. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.c +12 -8
  482. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb_minitable.h +7 -4
  483. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +12 -4
  484. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.c +9 -5
  485. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb_minitable.h +7 -4
  486. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +22 -4
  487. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.c +20 -14
  488. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb_minitable.h +9 -4
  489. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +18 -4
  490. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.c +19 -10
  491. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb_minitable.h +12 -4
  492. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +17 -4
  493. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.c +18 -11
  494. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb_minitable.h +10 -4
  495. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +9 -4
  496. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.c +10 -5
  497. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb_minitable.h +8 -4
  498. data/src/core/ext/upb-gen/envoy/type/v3/http.upb.h +5 -4
  499. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.c +3 -1
  500. data/src/core/ext/upb-gen/envoy/type/v3/http.upb_minitable.h +5 -4
  501. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb.h +5 -4
  502. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.c +4 -1
  503. data/src/core/ext/upb-gen/envoy/type/v3/http_status.upb_minitable.h +6 -4
  504. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb.h +5 -4
  505. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.c +5 -1
  506. data/src/core/ext/upb-gen/envoy/type/v3/percent.upb_minitable.h +7 -4
  507. data/src/core/ext/upb-gen/envoy/type/v3/range.upb.h +5 -4
  508. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.c +6 -1
  509. data/src/core/ext/upb-gen/envoy/type/v3/range.upb_minitable.h +8 -4
  510. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +9 -4
  511. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.c +9 -5
  512. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb_minitable.h +7 -4
  513. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb.h +5 -4
  514. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.c +3 -1
  515. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_unit.upb_minitable.h +5 -4
  516. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb.h +5 -4
  517. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.c +4 -1
  518. data/src/core/ext/upb-gen/envoy/type/v3/semantic_version.upb_minitable.h +6 -4
  519. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb.h +9 -4
  520. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.c +8 -5
  521. data/src/core/ext/upb-gen/envoy/type/v3/token_bucket.upb_minitable.h +6 -4
  522. data/src/core/ext/upb-gen/google/api/annotations.upb.h +7 -6
  523. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.c +5 -2
  524. data/src/core/ext/upb-gen/google/api/annotations.upb_minitable.h +5 -4
  525. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +87 -4
  526. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.c +69 -54
  527. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb_minitable.h +18 -4
  528. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +85 -4
  529. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.c +71 -53
  530. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb_minitable.h +21 -4
  531. data/src/core/ext/upb-gen/google/api/http.upb.h +18 -4
  532. data/src/core/ext/upb-gen/google/api/http.upb_minitable.c +13 -8
  533. data/src/core/ext/upb-gen/google/api/http.upb_minitable.h +8 -4
  534. data/src/core/ext/upb-gen/google/api/httpbody.upb.h +10 -4
  535. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.c +7 -4
  536. data/src/core/ext/upb-gen/google/api/httpbody.upb_minitable.h +6 -4
  537. data/src/core/ext/upb-gen/google/protobuf/any.upb.h +6 -4
  538. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.c +4 -1
  539. data/src/core/ext/upb-gen/google/protobuf/any.upb_minitable.h +6 -4
  540. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +202 -4
  541. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +241 -206
  542. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +55 -21
  543. data/src/core/ext/upb-gen/google/protobuf/duration.upb.h +6 -4
  544. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.c +4 -1
  545. data/src/core/ext/upb-gen/google/protobuf/duration.upb_minitable.h +6 -4
  546. data/src/core/ext/upb-gen/google/protobuf/empty.upb.h +6 -4
  547. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.c +4 -1
  548. data/src/core/ext/upb-gen/google/protobuf/empty.upb_minitable.h +6 -4
  549. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +27 -4
  550. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.c +20 -14
  551. data/src/core/ext/upb-gen/google/protobuf/struct.upb_minitable.h +9 -4
  552. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb.h +6 -4
  553. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.c +4 -1
  554. data/src/core/ext/upb-gen/google/protobuf/timestamp.upb_minitable.h +6 -4
  555. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb.h +6 -4
  556. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.c +12 -1
  557. data/src/core/ext/upb-gen/google/protobuf/wrappers.upb_minitable.h +14 -4
  558. data/src/core/ext/upb-gen/google/rpc/status.upb.h +10 -4
  559. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.c +7 -4
  560. data/src/core/ext/upb-gen/google/rpc/status.upb_minitable.h +6 -4
  561. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb.h +12 -4
  562. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.c +12 -6
  563. data/src/core/ext/upb-gen/opencensus/proto/trace/v1/trace_config.upb_minitable.h +9 -4
  564. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +13 -4
  565. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.c +9 -5
  566. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb_minitable.h +7 -4
  567. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +63 -4
  568. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +51 -37
  569. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.h +17 -4
  570. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +10 -4
  571. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +9 -5
  572. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.h +7 -4
  573. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb.h +6 -4
  574. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.c +5 -1
  575. data/src/core/ext/upb-gen/src/proto/grpc/health/v1/health.upb_minitable.h +7 -4
  576. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +29 -4
  577. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.c +31 -20
  578. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb_minitable.h +14 -4
  579. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +12 -4
  580. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.c +9 -4
  581. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb_minitable.h +8 -4
  582. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +57 -4
  583. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.c +33 -22
  584. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb_minitable.h +14 -4
  585. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb.h +15 -14
  586. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.c +22 -12
  587. data/src/core/ext/upb-gen/udpa/annotations/migrate.upb_minitable.h +8 -4
  588. data/src/core/ext/upb-gen/udpa/annotations/security.upb.h +7 -6
  589. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.c +10 -6
  590. data/src/core/ext/upb-gen/udpa/annotations/security.upb_minitable.h +6 -4
  591. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb.h +5 -4
  592. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.c +4 -1
  593. data/src/core/ext/upb-gen/udpa/annotations/sensitive.upb_minitable.h +5 -4
  594. data/src/core/ext/upb-gen/udpa/annotations/status.upb.h +7 -6
  595. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.c +10 -6
  596. data/src/core/ext/upb-gen/udpa/annotations/status.upb_minitable.h +6 -4
  597. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb.h +7 -6
  598. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.c +10 -6
  599. data/src/core/ext/upb-gen/udpa/annotations/versioning.upb_minitable.h +6 -4
  600. data/src/core/ext/upb-gen/validate/validate.upb.h +89 -6
  601. data/src/core/ext/upb-gen/validate/validate.upb_minitable.c +116 -87
  602. data/src/core/ext/upb-gen/validate/validate.upb_minitable.h +29 -5
  603. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb.h +15 -14
  604. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.c +22 -12
  605. data/src/core/ext/upb-gen/xds/annotations/v3/migrate.upb_minitable.h +8 -4
  606. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb.h +7 -6
  607. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.c +10 -6
  608. data/src/core/ext/upb-gen/xds/annotations/v3/security.upb_minitable.h +6 -4
  609. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb.h +5 -4
  610. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.c +4 -1
  611. data/src/core/ext/upb-gen/xds/annotations/v3/sensitive.upb_minitable.h +5 -4
  612. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb.h +11 -10
  613. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.c +20 -11
  614. data/src/core/ext/upb-gen/xds/annotations/v3/status.upb_minitable.h +9 -4
  615. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb.h +7 -6
  616. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.c +10 -6
  617. data/src/core/ext/upb-gen/xds/annotations/v3/versioning.upb_minitable.h +6 -4
  618. data/src/core/ext/upb-gen/xds/core/v3/authority.upb.h +5 -4
  619. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.c +4 -1
  620. data/src/core/ext/upb-gen/xds/core/v3/authority.upb_minitable.h +6 -4
  621. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb.h +7 -4
  622. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.c +7 -4
  623. data/src/core/ext/upb-gen/xds/core/v3/cidr.upb_minitable.h +6 -4
  624. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +11 -4
  625. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.c +12 -8
  626. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb_minitable.h +7 -4
  627. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb.h +11 -4
  628. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.c +8 -4
  629. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb_minitable.h +7 -4
  630. data/src/core/ext/upb-gen/xds/core/v3/extension.upb.h +7 -4
  631. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.c +7 -4
  632. data/src/core/ext/upb-gen/xds/core/v3/extension.upb_minitable.h +6 -4
  633. data/src/core/ext/upb-gen/xds/core/v3/resource.upb.h +9 -4
  634. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.c +8 -5
  635. data/src/core/ext/upb-gen/xds/core/v3/resource.upb_minitable.h +6 -4
  636. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +14 -4
  637. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.c +12 -8
  638. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb_minitable.h +7 -4
  639. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb.h +7 -4
  640. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.c +7 -4
  641. data/src/core/ext/upb-gen/xds/core/v3/resource_name.upb_minitable.h +6 -4
  642. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +23 -4
  643. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.c +12 -6
  644. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb_minitable.h +9 -4
  645. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb.h +7 -4
  646. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.c +7 -4
  647. data/src/core/ext/upb-gen/xds/service/orca/v3/orca.upb_minitable.h +6 -4
  648. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb.h +7 -4
  649. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.c +7 -4
  650. data/src/core/ext/upb-gen/xds/type/matcher/v3/cel.upb_minitable.h +6 -4
  651. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb.h +12 -4
  652. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.c +11 -7
  653. data/src/core/ext/upb-gen/xds/type/matcher/v3/domain.upb_minitable.h +7 -4
  654. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb.h +5 -4
  655. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.c +4 -1
  656. data/src/core/ext/upb-gen/xds/type/matcher/v3/http_inputs.upb_minitable.h +6 -4
  657. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb.h +17 -4
  658. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.c +12 -8
  659. data/src/core/ext/upb-gen/xds/type/matcher/v3/ip.upb_minitable.h +7 -4
  660. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +63 -4
  661. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.c +55 -43
  662. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb_minitable.h +15 -4
  663. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb.h +41 -4
  664. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.c +30 -22
  665. data/src/core/ext/upb-gen/xds/type/matcher/v3/range.upb_minitable.h +11 -4
  666. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +7 -4
  667. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.c +8 -4
  668. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb_minitable.h +7 -4
  669. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +12 -4
  670. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.c +11 -7
  671. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb_minitable.h +7 -4
  672. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +13 -4
  673. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.c +13 -9
  674. data/src/core/ext/upb-gen/xds/type/v3/cel.upb_minitable.h +7 -4
  675. data/src/core/ext/upb-gen/xds/type/v3/range.upb.h +6 -4
  676. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.c +6 -1
  677. data/src/core/ext/upb-gen/xds/type/v3/range.upb_minitable.h +8 -4
  678. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb.h +7 -4
  679. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.c +7 -4
  680. data/src/core/ext/upb-gen/xds/type/v3/typed_struct.upb_minitable.h +6 -4
  681. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.c +2 -1
  682. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.h +5 -4
  683. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.c +2 -1
  684. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.h +5 -4
  685. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.c +2 -1
  686. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.h +5 -4
  687. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.c +2 -1
  688. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.h +5 -4
  689. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.c +2 -1
  690. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.h +5 -4
  691. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.c +2 -1
  692. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.h +5 -4
  693. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.c +2 -1
  694. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.h +5 -4
  695. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.c +2 -1
  696. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.h +5 -4
  697. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.c +2 -1
  698. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.h +5 -4
  699. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +2 -1
  700. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.h +5 -4
  701. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.c +2 -1
  702. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.h +5 -4
  703. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.c +2 -1
  704. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.h +5 -4
  705. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.c +2 -1
  706. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.h +5 -4
  707. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +2 -1
  708. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.h +5 -4
  709. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +2 -1
  710. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +5 -4
  711. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +2 -1
  712. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +5 -4
  713. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +2 -1
  714. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +5 -4
  715. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +2 -1
  716. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.h +5 -4
  717. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +2 -1
  718. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.h +5 -4
  719. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +2 -1
  720. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.h +5 -4
  721. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +2 -1
  722. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.h +5 -4
  723. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.c +2 -1
  724. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.h +5 -4
  725. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +2 -1
  726. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +5 -4
  727. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +2 -1
  728. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.h +5 -4
  729. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.c +2 -1
  730. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.h +5 -4
  731. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.c +2 -1
  732. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.h +5 -4
  733. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.c +2 -1
  734. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.h +5 -4
  735. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +2 -1
  736. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.h +5 -4
  737. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +2 -1
  738. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.h +5 -4
  739. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +2 -1
  740. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +5 -4
  741. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +2 -1
  742. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.h +5 -4
  743. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +2 -1
  744. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.h +5 -4
  745. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.c +2 -1
  746. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.h +5 -4
  747. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.c +2 -1
  748. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.h +5 -4
  749. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.c +2 -1
  750. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.h +5 -4
  751. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +2 -1
  752. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +5 -4
  753. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.c +2 -1
  754. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.h +5 -4
  755. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +2 -1
  756. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.h +5 -4
  757. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +2 -1
  758. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +5 -4
  759. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +2 -1
  760. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +5 -4
  761. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.c +2 -1
  762. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.h +5 -4
  763. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +2 -1
  764. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.h +5 -4
  765. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.c +2 -1
  766. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.h +5 -4
  767. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +2 -1
  768. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.h +5 -4
  769. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.c +2 -1
  770. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.h +5 -4
  771. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.c +2 -1
  772. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.h +5 -4
  773. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.c +2 -1
  774. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.h +5 -4
  775. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.c +2 -1
  776. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.h +5 -4
  777. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +2 -1
  778. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.h +5 -4
  779. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +2 -1
  780. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.h +5 -4
  781. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +2 -1
  782. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.h +5 -4
  783. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.c +2 -1
  784. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.h +5 -4
  785. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +2 -1
  786. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.h +5 -4
  787. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +2 -1
  788. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +5 -4
  789. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +2 -1
  790. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.h +5 -4
  791. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.c +2 -1
  792. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.h +5 -4
  793. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.c +2 -1
  794. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.h +5 -4
  795. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.c +2 -1
  796. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opencensus.upbdefs.h +5 -4
  797. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +2 -1
  798. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.h +5 -4
  799. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.c +2 -1
  800. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.h +5 -4
  801. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.c +2 -1
  802. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.h +5 -4
  803. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.c +2 -1
  804. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.h +5 -4
  805. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.c +2 -1
  806. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.h +5 -4
  807. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +2 -1
  808. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.h +5 -4
  809. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +2 -1
  810. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.h +5 -4
  811. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +2 -1
  812. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +5 -4
  813. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +2 -1
  814. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +5 -4
  815. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +2 -1
  816. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +5 -4
  817. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +2 -1
  818. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +5 -4
  819. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +2 -1
  820. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +5 -4
  821. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +2 -1
  822. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.h +5 -4
  823. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +2 -1
  824. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +5 -4
  825. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +2 -1
  826. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -4
  827. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +2 -1
  828. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +5 -4
  829. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.c +53 -0
  830. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.h +33 -0
  831. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +2 -1
  832. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +5 -4
  833. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +2 -1
  834. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -4
  835. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +2 -1
  836. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +5 -4
  837. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +2 -1
  838. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +5 -4
  839. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +2 -1
  840. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +5 -4
  841. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.c +2 -1
  842. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.h +5 -4
  843. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.c +2 -1
  844. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.h +5 -4
  845. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.c +2 -1
  846. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.h +5 -4
  847. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.c +2 -1
  848. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.h +5 -4
  849. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +2 -1
  850. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.h +5 -4
  851. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.c +2 -1
  852. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.h +5 -4
  853. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.c +2 -1
  854. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.h +5 -4
  855. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.c +2 -1
  856. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.h +5 -4
  857. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  858. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.h +5 -4
  859. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.c +2 -1
  860. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.h +5 -4
  861. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.c +2 -1
  862. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.h +5 -4
  863. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.c +2 -1
  864. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.h +5 -4
  865. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.c +2 -1
  866. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.h +5 -4
  867. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.c +2 -1
  868. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.h +5 -4
  869. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.c +2 -1
  870. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.h +5 -4
  871. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +2 -1
  872. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.h +5 -4
  873. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.c +2 -1
  874. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.h +5 -4
  875. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +2 -1
  876. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +5 -4
  877. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.c +2 -1
  878. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.h +5 -4
  879. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.c +2 -1
  880. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.h +5 -4
  881. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.c +2 -1
  882. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.h +5 -4
  883. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.c +2 -1
  884. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.h +5 -4
  885. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.c +2 -1
  886. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.h +5 -4
  887. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.c +2 -1
  888. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.h +5 -4
  889. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.c +2 -1
  890. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.h +5 -4
  891. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.c +2 -1
  892. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.h +5 -4
  893. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.c +2 -1
  894. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.h +5 -4
  895. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.c +2 -1
  896. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.h +5 -4
  897. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.c +2 -1
  898. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.h +5 -4
  899. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.c +2 -1
  900. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.h +5 -4
  901. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +2 -1
  902. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.h +5 -4
  903. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +2 -1
  904. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +5 -4
  905. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.c +2 -1
  906. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.h +5 -4
  907. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.c +2 -1
  908. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.h +5 -4
  909. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.c +2 -1
  910. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.h +5 -4
  911. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +486 -484
  912. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +5 -4
  913. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.c +2 -1
  914. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.h +5 -4
  915. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.c +2 -1
  916. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.h +5 -4
  917. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.c +2 -1
  918. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.h +5 -4
  919. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.c +2 -1
  920. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.h +5 -4
  921. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.c +2 -1
  922. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.h +5 -4
  923. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.c +2 -1
  924. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.h +5 -4
  925. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.c +2 -1
  926. data/src/core/ext/upbdefs-gen/opencensus/proto/trace/v1/trace_config.upbdefs.h +5 -4
  927. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +2 -1
  928. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +5 -4
  929. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.c +2 -1
  930. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.h +5 -4
  931. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.c +2 -1
  932. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.h +5 -4
  933. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.c +2 -1
  934. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.h +5 -4
  935. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.c +2 -1
  936. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.h +5 -4
  937. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.c +2 -1
  938. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.h +5 -4
  939. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.c +2 -1
  940. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.h +5 -4
  941. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.c +2 -1
  942. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.h +5 -4
  943. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.c +2 -1
  944. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.h +5 -4
  945. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.c +2 -1
  946. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.h +5 -4
  947. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.c +2 -1
  948. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.h +5 -4
  949. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.c +2 -1
  950. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.h +5 -4
  951. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.c +2 -1
  952. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.h +5 -4
  953. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.c +2 -1
  954. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.h +5 -4
  955. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.c +2 -1
  956. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.h +5 -4
  957. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.c +2 -1
  958. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.h +5 -4
  959. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.c +2 -1
  960. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.h +5 -4
  961. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.c +2 -1
  962. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.h +5 -4
  963. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.c +2 -1
  964. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.h +5 -4
  965. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.c +2 -1
  966. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.h +5 -4
  967. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +2 -1
  968. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.h +5 -4
  969. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.c +2 -1
  970. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.h +5 -4
  971. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.c +2 -1
  972. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.h +5 -4
  973. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.c +2 -1
  974. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.h +5 -4
  975. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.c +2 -1
  976. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.h +5 -4
  977. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.c +2 -1
  978. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.h +5 -4
  979. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.c +2 -1
  980. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.h +5 -4
  981. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.c +2 -1
  982. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.h +5 -4
  983. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.c +2 -1
  984. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.h +5 -4
  985. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.c +2 -1
  986. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.h +5 -4
  987. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.c +2 -1
  988. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.h +5 -4
  989. data/src/core/filter/blackboard.cc +33 -0
  990. data/src/core/filter/blackboard.h +70 -0
  991. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.cc +4 -5
  992. data/src/core/handshaker/endpoint_info/endpoint_info_handshaker.h +1 -1
  993. data/src/core/handshaker/handshaker.cc +8 -11
  994. data/src/core/handshaker/handshaker.h +8 -10
  995. data/src/core/handshaker/handshaker_registry.cc +1 -2
  996. data/src/core/handshaker/handshaker_registry.h +2 -2
  997. data/src/core/handshaker/http_connect/http_connect_handshaker.cc +14 -11
  998. data/src/core/handshaker/http_connect/http_connect_handshaker.h +1 -1
  999. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +7 -9
  1000. data/src/core/handshaker/http_connect/http_proxy_mapper.h +3 -4
  1001. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.cc +57 -0
  1002. data/src/core/handshaker/http_connect/xds_http_proxy_mapper.h +46 -0
  1003. data/src/core/handshaker/proxy_mapper.h +2 -3
  1004. data/src/core/handshaker/proxy_mapper_registry.cc +2 -2
  1005. data/src/core/handshaker/proxy_mapper_registry.h +2 -3
  1006. data/src/core/handshaker/security/secure_endpoint.cc +12 -14
  1007. data/src/core/handshaker/security/secure_endpoint.h +2 -3
  1008. data/src/core/handshaker/security/security_handshaker.cc +15 -21
  1009. data/src/core/handshaker/security/security_handshaker.h +3 -4
  1010. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.cc +10 -11
  1011. data/src/core/handshaker/tcp_connect/tcp_connect_handshaker.h +1 -1
  1012. data/src/core/lib/address_utils/parse_address.cc +3 -4
  1013. data/src/core/lib/address_utils/parse_address.h +2 -4
  1014. data/src/core/lib/address_utils/sockaddr_utils.cc +4 -6
  1015. data/src/core/lib/address_utils/sockaddr_utils.h +1 -3
  1016. data/src/core/lib/channel/call_finalization.h +2 -2
  1017. data/src/core/lib/channel/channel_args.cc +4 -6
  1018. data/src/core/lib/channel/channel_args.h +11 -13
  1019. data/src/core/lib/channel/channel_args_preconditioning.cc +2 -2
  1020. data/src/core/lib/channel/channel_args_preconditioning.h +4 -4
  1021. data/src/core/lib/channel/channel_stack.cc +5 -4
  1022. data/src/core/lib/channel/channel_stack.h +17 -17
  1023. data/src/core/lib/channel/channel_stack_builder.cc +2 -2
  1024. data/src/core/lib/channel/channel_stack_builder.h +3 -4
  1025. data/src/core/lib/channel/channel_stack_builder_impl.cc +5 -7
  1026. data/src/core/lib/channel/channel_stack_builder_impl.h +15 -3
  1027. data/src/core/lib/channel/connected_channel.cc +9 -11
  1028. data/src/core/lib/channel/promise_based_filter.cc +33 -24
  1029. data/src/core/lib/channel/promise_based_filter.h +45 -16
  1030. data/src/core/lib/channel/status_util.cc +1 -3
  1031. data/src/core/lib/channel/status_util.h +3 -3
  1032. data/src/core/lib/compression/compression.cc +3 -5
  1033. data/src/core/lib/compression/compression_internal.cc +5 -7
  1034. data/src/core/lib/compression/compression_internal.h +3 -5
  1035. data/src/core/lib/compression/message_compress.cc +3 -6
  1036. data/src/core/lib/debug/trace.cc +5 -6
  1037. data/src/core/lib/debug/trace_flags.cc +1 -2
  1038. data/src/core/lib/debug/trace_impl.h +2 -2
  1039. data/src/core/lib/event_engine/ares_resolver.cc +11 -15
  1040. data/src/core/lib/event_engine/ares_resolver.h +7 -10
  1041. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +2 -4
  1042. data/src/core/lib/event_engine/cf_engine/cf_engine.h +1 -1
  1043. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +1 -2
  1044. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +4 -6
  1045. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.cc +9 -7
  1046. data/src/core/lib/event_engine/cf_engine/dns_service_resolver.h +3 -5
  1047. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +3 -4
  1048. data/src/core/lib/event_engine/channel_args_endpoint_config.h +2 -3
  1049. data/src/core/lib/event_engine/common_closures.h +3 -3
  1050. data/src/core/lib/event_engine/default_event_engine.cc +7 -8
  1051. data/src/core/lib/event_engine/default_event_engine.h +4 -4
  1052. data/src/core/lib/event_engine/default_event_engine_factory.cc +2 -2
  1053. data/src/core/lib/event_engine/default_event_engine_factory.h +2 -2
  1054. data/src/core/lib/event_engine/event_engine.cc +2 -2
  1055. data/src/core/lib/event_engine/extensions/can_track_errors.h +2 -2
  1056. data/src/core/lib/event_engine/extensions/chaotic_good_extension.h +1 -2
  1057. data/src/core/lib/event_engine/extensions/supports_fd.h +20 -3
  1058. data/src/core/lib/event_engine/extensions/tcp_trace.h +0 -1
  1059. data/src/core/lib/event_engine/forkable.cc +3 -3
  1060. data/src/core/lib/event_engine/forkable.h +2 -2
  1061. data/src/core/lib/event_engine/grpc_polled_fd.h +3 -4
  1062. data/src/core/lib/event_engine/handle_containers.h +2 -3
  1063. data/src/core/lib/event_engine/memory_allocator_factory.h +3 -4
  1064. data/src/core/lib/event_engine/nameser.h +1 -1
  1065. data/src/core/lib/event_engine/poller.h +2 -2
  1066. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.cc +10 -12
  1067. data/src/core/lib/event_engine/posix_engine/ev_epoll1_linux.h +4 -5
  1068. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.cc +17 -20
  1069. data/src/core/lib/event_engine/posix_engine/ev_poll_posix.h +4 -5
  1070. data/src/core/lib/event_engine/posix_engine/event_poller.h +3 -4
  1071. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.cc +4 -5
  1072. data/src/core/lib/event_engine/posix_engine/event_poller_posix_default.h +2 -2
  1073. data/src/core/lib/event_engine/posix_engine/grpc_polled_fd_posix.h +4 -6
  1074. data/src/core/lib/event_engine/posix_engine/internal_errqueue.cc +2 -3
  1075. data/src/core/lib/event_engine/posix_engine/internal_errqueue.h +1 -2
  1076. data/src/core/lib/event_engine/posix_engine/lockfree_event.cc +5 -6
  1077. data/src/core/lib/event_engine/posix_engine/lockfree_event.h +2 -3
  1078. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +2 -3
  1079. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +2 -3
  1080. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +15 -17
  1081. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +8 -9
  1082. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +44 -28
  1083. data/src/core/lib/event_engine/posix_engine/posix_engine.h +16 -14
  1084. data/src/core/lib/event_engine/posix_engine/posix_engine_closure.h +3 -3
  1085. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +7 -9
  1086. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +12 -11
  1087. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.cc +4 -6
  1088. data/src/core/lib/event_engine/posix_engine/posix_engine_listener_utils.h +1 -2
  1089. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +8 -11
  1090. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +7 -8
  1091. data/src/core/lib/event_engine/posix_engine/timer.cc +4 -4
  1092. data/src/core/lib/event_engine/posix_engine/timer.h +5 -7
  1093. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +2 -3
  1094. data/src/core/lib/event_engine/posix_engine/timer_heap.h +2 -2
  1095. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +3 -4
  1096. data/src/core/lib/event_engine/posix_engine/timer_manager.h +5 -7
  1097. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.cc +5 -7
  1098. data/src/core/lib/event_engine/posix_engine/traced_buffer_list.h +3 -5
  1099. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.cc +5 -6
  1100. data/src/core/lib/event_engine/posix_engine/wakeup_fd_eventfd.h +2 -3
  1101. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.cc +4 -5
  1102. data/src/core/lib/event_engine/posix_engine/wakeup_fd_pipe.h +2 -3
  1103. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix.h +2 -2
  1104. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.cc +2 -3
  1105. data/src/core/lib/event_engine/posix_engine/wakeup_fd_posix_default.h +2 -2
  1106. data/src/core/lib/event_engine/query_extensions.h +2 -2
  1107. data/src/core/lib/event_engine/ref_counted_dns_resolver_interface.h +3 -5
  1108. data/src/core/lib/event_engine/resolved_address.cc +5 -4
  1109. data/src/core/lib/event_engine/slice.cc +3 -5
  1110. data/src/core/lib/event_engine/slice_buffer.cc +1 -2
  1111. data/src/core/lib/event_engine/tcp_socket_utils.cc +3 -10
  1112. data/src/core/lib/event_engine/tcp_socket_utils.h +3 -3
  1113. data/src/core/lib/event_engine/thread_pool/thread_count.cc +2 -4
  1114. data/src/core/lib/event_engine/thread_pool/thread_count.h +5 -6
  1115. data/src/core/lib/event_engine/thread_pool/thread_pool.h +2 -4
  1116. data/src/core/lib/event_engine/thread_pool/thread_pool_factory.cc +2 -3
  1117. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.cc +9 -11
  1118. data/src/core/lib/event_engine/thread_pool/work_stealing_thread_pool.h +7 -9
  1119. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.cc +5 -5
  1120. data/src/core/lib/event_engine/thready_event_engine/thready_event_engine.h +5 -5
  1121. data/src/core/lib/event_engine/time_util.cc +2 -2
  1122. data/src/core/lib/event_engine/time_util.h +1 -2
  1123. data/src/core/lib/event_engine/utils.cc +19 -5
  1124. data/src/core/lib/event_engine/utils.h +10 -4
  1125. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.cc +5 -8
  1126. data/src/core/lib/event_engine/windows/grpc_polled_fd_windows.h +4 -6
  1127. data/src/core/lib/event_engine/windows/iocp.cc +4 -5
  1128. data/src/core/lib/event_engine/windows/iocp.h +1 -2
  1129. data/src/core/lib/event_engine/windows/native_windows_dns_resolver.cc +4 -6
  1130. data/src/core/lib/event_engine/windows/win_socket.cc +4 -5
  1131. data/src/core/lib/event_engine/windows/win_socket.h +4 -5
  1132. data/src/core/lib/event_engine/windows/windows_endpoint.cc +28 -15
  1133. data/src/core/lib/event_engine/windows/windows_engine.cc +10 -11
  1134. data/src/core/lib/event_engine/windows/windows_engine.h +8 -9
  1135. data/src/core/lib/event_engine/windows/windows_listener.cc +2 -3
  1136. data/src/core/lib/event_engine/windows/windows_listener.h +4 -5
  1137. data/src/core/lib/event_engine/work_queue/basic_work_queue.cc +3 -3
  1138. data/src/core/lib/event_engine/work_queue/basic_work_queue.h +3 -5
  1139. data/src/core/lib/event_engine/work_queue/work_queue.h +2 -3
  1140. data/src/core/lib/experiments/config.cc +9 -12
  1141. data/src/core/lib/experiments/config.h +1 -2
  1142. data/src/core/lib/experiments/experiments.cc +203 -28
  1143. data/src/core/lib/experiments/experiments.h +76 -15
  1144. data/src/core/lib/iomgr/buffer_list.cc +4 -5
  1145. data/src/core/lib/iomgr/buffer_list.h +2 -3
  1146. data/src/core/lib/iomgr/call_combiner.cc +2 -4
  1147. data/src/core/lib/iomgr/call_combiner.h +6 -8
  1148. data/src/core/lib/iomgr/cfstream_handle.cc +2 -4
  1149. data/src/core/lib/iomgr/cfstream_handle.h +1 -1
  1150. data/src/core/lib/iomgr/closure.cc +2 -2
  1151. data/src/core/lib/iomgr/closure.h +9 -9
  1152. data/src/core/lib/iomgr/combiner.cc +4 -6
  1153. data/src/core/lib/iomgr/combiner.h +2 -3
  1154. data/src/core/lib/iomgr/endpoint.h +1 -2
  1155. data/src/core/lib/iomgr/endpoint_cfstream.cc +2 -4
  1156. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -4
  1157. data/src/core/lib/iomgr/endpoint_pair_windows.cc +1 -2
  1158. data/src/core/lib/iomgr/error.cc +6 -8
  1159. data/src/core/lib/iomgr/error.h +6 -8
  1160. data/src/core/lib/iomgr/error_cfstream.cc +1 -3
  1161. data/src/core/lib/iomgr/ev_apple.cc +3 -4
  1162. data/src/core/lib/iomgr/ev_epoll1_linux.cc +7 -9
  1163. data/src/core/lib/iomgr/ev_poll_posix.cc +3 -5
  1164. data/src/core/lib/iomgr/ev_posix.cc +4 -6
  1165. data/src/core/lib/iomgr/ev_posix.h +1 -2
  1166. data/src/core/lib/iomgr/event_engine_shims/closure.cc +3 -4
  1167. data/src/core/lib/iomgr/event_engine_shims/closure.h +1 -2
  1168. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +10 -11
  1169. data/src/core/lib/iomgr/event_engine_shims/endpoint.h +2 -2
  1170. data/src/core/lib/iomgr/event_engine_shims/tcp_client.cc +2 -3
  1171. data/src/core/lib/iomgr/exec_ctx.cc +4 -5
  1172. data/src/core/lib/iomgr/exec_ctx.h +6 -8
  1173. data/src/core/lib/iomgr/executor.cc +6 -8
  1174. data/src/core/lib/iomgr/executor.h +1 -1
  1175. data/src/core/lib/iomgr/fork_posix.cc +5 -7
  1176. data/src/core/lib/iomgr/fork_windows.cc +2 -2
  1177. data/src/core/lib/iomgr/internal_errqueue.cc +2 -3
  1178. data/src/core/lib/iomgr/iocp_windows.cc +4 -6
  1179. data/src/core/lib/iomgr/iomgr.cc +7 -9
  1180. data/src/core/lib/iomgr/iomgr.h +1 -2
  1181. data/src/core/lib/iomgr/iomgr_internal.cc +1 -2
  1182. data/src/core/lib/iomgr/iomgr_internal.h +1 -2
  1183. data/src/core/lib/iomgr/iomgr_posix.cc +2 -1
  1184. data/src/core/lib/iomgr/iomgr_windows.cc +4 -3
  1185. data/src/core/lib/iomgr/lockfree_event.cc +3 -4
  1186. data/src/core/lib/iomgr/nameser.h +1 -1
  1187. data/src/core/lib/iomgr/polling_entity.cc +3 -4
  1188. data/src/core/lib/iomgr/pollset_set_windows.cc +1 -2
  1189. data/src/core/lib/iomgr/pollset_windows.cc +2 -2
  1190. data/src/core/lib/iomgr/port.h +2 -2
  1191. data/src/core/lib/iomgr/resolve_address.cc +3 -4
  1192. data/src/core/lib/iomgr/resolve_address.h +4 -6
  1193. data/src/core/lib/iomgr/resolve_address_impl.h +1 -2
  1194. data/src/core/lib/iomgr/resolve_address_posix.cc +6 -7
  1195. data/src/core/lib/iomgr/resolve_address_posix.h +2 -2
  1196. data/src/core/lib/iomgr/resolve_address_windows.cc +8 -10
  1197. data/src/core/lib/iomgr/resolve_address_windows.h +2 -2
  1198. data/src/core/lib/iomgr/resolved_address.h +1 -2
  1199. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +3 -5
  1200. data/src/core/lib/iomgr/socket_mutator.cc +1 -1
  1201. data/src/core/lib/iomgr/socket_mutator.h +1 -2
  1202. data/src/core/lib/iomgr/socket_utils.h +1 -2
  1203. data/src/core/lib/iomgr/socket_utils_common_posix.cc +5 -7
  1204. data/src/core/lib/iomgr/socket_utils_linux.cc +1 -1
  1205. data/src/core/lib/iomgr/socket_utils_posix.cc +4 -6
  1206. data/src/core/lib/iomgr/socket_utils_windows.cc +1 -1
  1207. data/src/core/lib/iomgr/socket_windows.cc +3 -5
  1208. data/src/core/lib/iomgr/socket_windows.h +1 -2
  1209. data/src/core/lib/iomgr/tcp_client_cfstream.cc +5 -7
  1210. data/src/core/lib/iomgr/tcp_client_posix.cc +5 -7
  1211. data/src/core/lib/iomgr/tcp_client_windows.cc +6 -8
  1212. data/src/core/lib/iomgr/tcp_posix.cc +14 -17
  1213. data/src/core/lib/iomgr/tcp_posix.h +1 -1
  1214. data/src/core/lib/iomgr/tcp_server.h +2 -2
  1215. data/src/core/lib/iomgr/tcp_server_posix.cc +9 -11
  1216. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -3
  1217. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +3 -5
  1218. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +4 -6
  1219. data/src/core/lib/iomgr/tcp_server_windows.cc +11 -13
  1220. data/src/core/lib/iomgr/tcp_windows.cc +4 -6
  1221. data/src/core/lib/iomgr/timer.h +2 -2
  1222. data/src/core/lib/iomgr/timer_generic.cc +9 -11
  1223. data/src/core/lib/iomgr/timer_heap.cc +2 -3
  1224. data/src/core/lib/iomgr/timer_manager.cc +4 -6
  1225. data/src/core/lib/iomgr/timer_manager.h +1 -2
  1226. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -4
  1227. data/src/core/lib/iomgr/unix_sockets_posix.h +3 -4
  1228. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -2
  1229. data/src/core/lib/iomgr/vsock.cc +2 -4
  1230. data/src/core/lib/iomgr/vsock.h +3 -4
  1231. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +2 -2
  1232. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +3 -4
  1233. data/src/core/lib/promise/activity.cc +2 -4
  1234. data/src/core/lib/promise/activity.h +10 -12
  1235. data/src/core/lib/promise/all_ok.h +40 -4
  1236. data/src/core/lib/promise/arena_promise.h +2 -4
  1237. data/src/core/lib/promise/cancel_callback.h +4 -4
  1238. data/src/core/lib/promise/context.h +7 -8
  1239. data/src/core/lib/promise/detail/basic_seq.h +33 -19
  1240. data/src/core/lib/promise/detail/join_state.h +4 -5
  1241. data/src/core/lib/promise/detail/promise_factory.h +7 -8
  1242. data/src/core/lib/promise/detail/promise_like.h +26 -4
  1243. data/src/core/lib/promise/detail/seq_state.h +183 -185
  1244. data/src/core/lib/promise/detail/status.h +5 -5
  1245. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +2 -3
  1246. data/src/core/lib/promise/for_each.h +9 -10
  1247. data/src/core/lib/promise/if.h +9 -9
  1248. data/src/core/lib/promise/interceptor_list.h +3 -5
  1249. data/src/core/lib/promise/latch.h +1 -3
  1250. data/src/core/lib/promise/loop.h +13 -5
  1251. data/src/core/lib/promise/map.h +57 -7
  1252. data/src/core/lib/promise/observable.h +3 -4
  1253. data/src/core/lib/promise/party.cc +42 -76
  1254. data/src/core/lib/promise/party.h +60 -40
  1255. data/src/core/lib/promise/pipe.h +3 -5
  1256. data/src/core/lib/promise/poll.h +19 -7
  1257. data/src/core/lib/promise/prioritized_race.h +2 -2
  1258. data/src/core/lib/promise/promise.h +5 -6
  1259. data/src/core/lib/promise/race.h +4 -4
  1260. data/src/core/lib/promise/seq.h +17 -39
  1261. data/src/core/lib/promise/sleep.cc +3 -3
  1262. data/src/core/lib/promise/sleep.h +4 -5
  1263. data/src/core/lib/promise/status_flag.h +9 -3
  1264. data/src/core/lib/promise/try_join.h +5 -5
  1265. data/src/core/lib/promise/try_seq.h +45 -47
  1266. data/src/core/lib/resource_quota/api.cc +4 -6
  1267. data/src/core/lib/resource_quota/api.h +2 -3
  1268. data/src/core/lib/resource_quota/arena.cc +3 -4
  1269. data/src/core/lib/resource_quota/arena.h +4 -5
  1270. data/src/core/lib/resource_quota/connection_quota.cc +2 -2
  1271. data/src/core/lib/resource_quota/connection_quota.h +5 -6
  1272. data/src/core/lib/resource_quota/memory_quota.cc +20 -11
  1273. data/src/core/lib/resource_quota/memory_quota.h +21 -13
  1274. data/src/core/lib/resource_quota/periodic_update.cc +4 -4
  1275. data/src/core/lib/resource_quota/periodic_update.h +2 -4
  1276. data/src/core/lib/resource_quota/resource_quota.h +7 -8
  1277. data/src/core/lib/resource_quota/thread_quota.cc +2 -2
  1278. data/src/core/lib/resource_quota/thread_quota.h +5 -6
  1279. data/src/core/lib/security/authorization/audit_logging.cc +5 -6
  1280. data/src/core/lib/security/authorization/audit_logging.h +5 -6
  1281. data/src/core/lib/security/authorization/authorization_engine.h +3 -3
  1282. data/src/core/lib/security/authorization/authorization_policy_provider.h +3 -4
  1283. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +1 -1
  1284. data/src/core/lib/security/authorization/evaluate_args.cc +4 -6
  1285. data/src/core/lib/security/authorization/evaluate_args.h +3 -4
  1286. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +2 -3
  1287. data/src/core/lib/security/authorization/grpc_authorization_engine.h +2 -3
  1288. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +5 -3
  1289. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +2 -3
  1290. data/src/core/lib/security/authorization/matchers.cc +2 -4
  1291. data/src/core/lib/security/authorization/matchers.h +2 -4
  1292. data/src/core/lib/security/authorization/rbac_policy.cc +2 -2
  1293. data/src/core/lib/security/authorization/rbac_policy.h +3 -5
  1294. data/src/core/lib/security/authorization/stdout_logger.cc +4 -4
  1295. data/src/core/lib/security/authorization/stdout_logger.h +4 -4
  1296. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +6 -7
  1297. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +2 -2
  1298. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +2 -3
  1299. data/src/core/lib/security/context/security_context.cc +6 -8
  1300. data/src/core/lib/security/context/security_context.h +16 -10
  1301. data/src/core/lib/security/credentials/alts/alts_credentials.cc +5 -5
  1302. data/src/core/lib/security/credentials/alts/alts_credentials.h +8 -4
  1303. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +2 -3
  1304. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +1 -2
  1305. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +1 -2
  1306. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +3 -4
  1307. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +1 -2
  1308. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +2 -2
  1309. data/src/core/lib/security/credentials/call_creds_util.cc +6 -5
  1310. data/src/core/lib/security/credentials/call_creds_util.h +2 -2
  1311. data/src/core/lib/security/credentials/channel_creds_registry.h +5 -6
  1312. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +10 -11
  1313. data/src/core/lib/security/credentials/composite/composite_credentials.cc +3 -4
  1314. data/src/core/lib/security/credentials/composite/composite_credentials.h +8 -9
  1315. data/src/core/lib/security/credentials/credentials.cc +1 -4
  1316. data/src/core/lib/security/credentials/credentials.h +11 -12
  1317. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +10 -12
  1318. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +7 -6
  1319. data/src/core/lib/security/credentials/external/aws_request_signer.cc +4 -5
  1320. data/src/core/lib/security/credentials/external/aws_request_signer.h +3 -3
  1321. data/src/core/lib/security/credentials/external/external_account_credentials.cc +15 -16
  1322. data/src/core/lib/security/credentials/external/external_account_credentials.h +5 -7
  1323. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +6 -7
  1324. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +6 -5
  1325. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +8 -10
  1326. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +8 -7
  1327. data/src/core/lib/security/credentials/fake/fake_credentials.cc +2 -4
  1328. data/src/core/lib/security/credentials/fake/fake_credentials.h +6 -7
  1329. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +5 -6
  1330. data/src/core/lib/security/credentials/gcp_service_account_identity/gcp_service_account_identity_credentials.h +7 -7
  1331. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +3 -4
  1332. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +18 -21
  1333. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +7 -5
  1334. data/src/core/lib/security/credentials/iam/iam_credentials.cc +2 -4
  1335. data/src/core/lib/security/credentials/iam/iam_credentials.h +5 -6
  1336. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +2 -2
  1337. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +2 -2
  1338. data/src/core/lib/security/credentials/jwt/json_token.cc +11 -14
  1339. data/src/core/lib/security/credentials/jwt/json_token.h +1 -2
  1340. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +8 -10
  1341. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +7 -9
  1342. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +19 -22
  1343. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +2 -3
  1344. data/src/core/lib/security/credentials/local/local_credentials.cc +2 -2
  1345. data/src/core/lib/security/credentials/local/local_credentials.h +2 -2
  1346. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +14 -16
  1347. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +12 -13
  1348. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +3 -4
  1349. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +9 -11
  1350. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +4 -6
  1351. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +4 -6
  1352. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +3 -3
  1353. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +4 -5
  1354. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_match.cc +1 -3
  1355. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +79 -9
  1356. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +13 -11
  1357. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +4 -6
  1358. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +8 -9
  1359. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -5
  1360. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +1 -1
  1361. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.cc +3 -5
  1362. data/src/core/lib/security/credentials/tls/grpc_tls_crl_provider.h +8 -10
  1363. data/src/core/lib/security/credentials/tls/tls_credentials.cc +6 -7
  1364. data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -3
  1365. data/src/core/lib/security/credentials/tls/tls_utils.cc +1 -2
  1366. data/src/core/lib/security/credentials/tls/tls_utils.h +3 -3
  1367. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.cc +29 -22
  1368. data/src/core/lib/security/credentials/token_fetcher/token_fetcher_credentials.h +15 -10
  1369. data/src/core/lib/security/credentials/xds/xds_credentials.cc +2 -3
  1370. data/src/core/lib/security/credentials/xds/xds_credentials.h +7 -9
  1371. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +9 -11
  1372. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +1 -1
  1373. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +9 -11
  1374. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +1 -1
  1375. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +4 -6
  1376. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +5 -6
  1377. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +5 -7
  1378. data/src/core/lib/security/security_connector/load_system_roots_windows.cc +3 -4
  1379. data/src/core/lib/security/security_connector/local/local_security_connector.cc +17 -13
  1380. data/src/core/lib/security/security_connector/local/local_security_connector.h +1 -1
  1381. data/src/core/lib/security/security_connector/security_connector.cc +2 -4
  1382. data/src/core/lib/security/security_connector/security_connector.h +7 -8
  1383. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +6 -8
  1384. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +2 -3
  1385. data/src/core/lib/security/security_connector/ssl_utils.cc +12 -14
  1386. data/src/core/lib/security/security_connector/ssl_utils.h +7 -9
  1387. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +8 -10
  1388. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +7 -8
  1389. data/src/core/lib/security/transport/auth_filters.h +2 -3
  1390. data/src/core/lib/security/transport/client_auth_filter.cc +8 -10
  1391. data/src/core/lib/security/transport/server_auth_filter.cc +10 -11
  1392. data/src/core/lib/security/util/json_util.cc +4 -5
  1393. data/src/core/lib/slice/percent_encoding.cc +2 -4
  1394. data/src/core/lib/slice/slice.cc +4 -6
  1395. data/src/core/lib/slice/slice.h +5 -7
  1396. data/src/core/lib/slice/slice_buffer.cc +5 -6
  1397. data/src/core/lib/slice/slice_buffer.h +3 -4
  1398. data/src/core/lib/slice/slice_internal.h +3 -5
  1399. data/src/core/lib/slice/slice_refcount.h +2 -3
  1400. data/src/core/lib/slice/slice_string_helpers.h +1 -2
  1401. data/src/core/lib/surface/byte_buffer.cc +1 -2
  1402. data/src/core/lib/surface/byte_buffer_reader.cc +3 -5
  1403. data/src/core/lib/surface/call.cc +22 -24
  1404. data/src/core/lib/surface/call.h +6 -8
  1405. data/src/core/lib/surface/call_log_batch.cc +3 -5
  1406. data/src/core/lib/surface/call_test_only.h +1 -2
  1407. data/src/core/lib/surface/call_utils.cc +16 -59
  1408. data/src/core/lib/surface/call_utils.h +57 -19
  1409. data/src/core/lib/surface/channel.cc +1 -2
  1410. data/src/core/lib/surface/channel.h +11 -12
  1411. data/src/core/lib/surface/channel_create.cc +2 -3
  1412. data/src/core/lib/surface/channel_create.h +2 -3
  1413. data/src/core/lib/surface/channel_init.cc +4 -6
  1414. data/src/core/lib/surface/channel_init.h +4 -6
  1415. data/src/core/lib/surface/client_call.cc +66 -54
  1416. data/src/core/lib/surface/client_call.h +27 -19
  1417. data/src/core/lib/surface/completion_queue.cc +12 -14
  1418. data/src/core/lib/surface/completion_queue.h +4 -5
  1419. data/src/core/lib/surface/completion_queue_factory.cc +1 -2
  1420. data/src/core/lib/surface/connection_context.cc +77 -0
  1421. data/src/core/lib/surface/connection_context.h +156 -0
  1422. data/src/core/lib/surface/event_string.cc +2 -2
  1423. data/src/core/lib/surface/event_string.h +2 -2
  1424. data/src/core/lib/surface/filter_stack_call.cc +18 -20
  1425. data/src/core/lib/surface/filter_stack_call.h +16 -18
  1426. data/src/core/lib/surface/init.cc +28 -7
  1427. data/src/core/lib/surface/init.h +5 -0
  1428. data/src/core/lib/surface/lame_client.cc +10 -11
  1429. data/src/core/lib/surface/lame_client.h +4 -5
  1430. data/src/core/lib/surface/legacy_channel.cc +11 -12
  1431. data/src/core/lib/surface/legacy_channel.h +6 -7
  1432. data/src/core/lib/surface/metadata_array.cc +1 -2
  1433. data/src/core/lib/surface/server_call.cc +22 -18
  1434. data/src/core/lib/surface/server_call.h +19 -20
  1435. data/src/core/lib/surface/validate_metadata.cc +3 -4
  1436. data/src/core/lib/surface/validate_metadata.h +2 -4
  1437. data/src/core/lib/surface/version.cc +2 -2
  1438. data/src/core/lib/transport/bdp_estimator.cc +2 -3
  1439. data/src/core/lib/transport/bdp_estimator.h +3 -5
  1440. data/src/core/lib/transport/call_arena_allocator.cc +2 -2
  1441. data/src/core/lib/transport/call_arena_allocator.h +2 -3
  1442. data/src/core/lib/transport/call_destination.h +1 -1
  1443. data/src/core/lib/transport/call_filters.cc +5 -117
  1444. data/src/core/lib/transport/call_filters.h +402 -35
  1445. data/src/core/lib/transport/call_final_info.cc +2 -2
  1446. data/src/core/lib/transport/call_final_info.h +3 -3
  1447. data/src/core/lib/transport/call_spine.cc +1 -6
  1448. data/src/core/lib/transport/call_spine.h +29 -12
  1449. data/src/core/lib/transport/call_state.h +145 -41
  1450. data/src/core/lib/transport/connectivity_state.cc +3 -4
  1451. data/src/core/lib/transport/connectivity_state.h +5 -6
  1452. data/src/core/lib/transport/error_utils.cc +3 -4
  1453. data/src/core/lib/transport/error_utils.h +4 -5
  1454. data/src/core/lib/transport/interception_chain.cc +3 -3
  1455. data/src/core/lib/transport/interception_chain.h +17 -8
  1456. data/src/core/lib/transport/message.cc +2 -2
  1457. data/src/core/lib/transport/message.h +5 -0
  1458. data/src/core/lib/transport/metadata_batch.cc +12 -5
  1459. data/src/core/lib/transport/metadata_batch.h +17 -11
  1460. data/src/core/lib/transport/metadata_compression_traits.h +3 -4
  1461. data/src/core/lib/transport/parsed_metadata.h +3 -5
  1462. data/src/core/lib/transport/simple_slice_based_metadata.h +1 -2
  1463. data/src/core/lib/transport/status_conversion.h +1 -1
  1464. data/src/core/lib/transport/timeout_encoding.cc +7 -7
  1465. data/src/core/lib/transport/timeout_encoding.h +2 -4
  1466. data/src/core/lib/transport/transport.cc +4 -6
  1467. data/src/core/lib/transport/transport.h +7 -9
  1468. data/src/core/lib/transport/transport_framing_endpoint_extension.h +47 -0
  1469. data/src/core/lib/transport/transport_op_string.cc +4 -5
  1470. data/src/core/load_balancing/address_filtering.cc +2 -4
  1471. data/src/core/load_balancing/address_filtering.h +4 -5
  1472. data/src/core/load_balancing/backend_metric_data.h +2 -2
  1473. data/src/core/load_balancing/backend_metric_parser.cc +1 -2
  1474. data/src/core/load_balancing/backend_metric_parser.h +1 -3
  1475. data/src/core/load_balancing/child_policy_handler.cc +5 -6
  1476. data/src/core/load_balancing/child_policy_handler.h +4 -5
  1477. data/src/core/load_balancing/delegating_helper.h +6 -7
  1478. data/src/core/load_balancing/endpoint_list.cc +7 -9
  1479. data/src/core/load_balancing/endpoint_list.h +6 -8
  1480. data/src/core/load_balancing/grpclb/client_load_reporting_filter.cc +10 -4
  1481. data/src/core/load_balancing/grpclb/client_load_reporting_filter.h +1 -2
  1482. data/src/core/load_balancing/grpclb/grpclb.cc +20 -22
  1483. data/src/core/load_balancing/grpclb/grpclb_balancer_addresses.cc +1 -2
  1484. data/src/core/load_balancing/grpclb/grpclb_client_stats.cc +2 -3
  1485. data/src/core/load_balancing/grpclb/grpclb_client_stats.h +5 -7
  1486. data/src/core/load_balancing/grpclb/load_balancer_api.cc +4 -6
  1487. data/src/core/load_balancing/grpclb/load_balancer_api.h +4 -6
  1488. data/src/core/load_balancing/health_check_client.cc +20 -20
  1489. data/src/core/load_balancing/health_check_client.h +3 -3
  1490. data/src/core/load_balancing/health_check_client_internal.h +8 -9
  1491. data/src/core/load_balancing/lb_policy.h +13 -15
  1492. data/src/core/load_balancing/lb_policy_factory.h +4 -5
  1493. data/src/core/load_balancing/lb_policy_registry.cc +3 -4
  1494. data/src/core/load_balancing/lb_policy_registry.h +4 -5
  1495. data/src/core/load_balancing/oob_backend_metric.cc +14 -16
  1496. data/src/core/load_balancing/oob_backend_metric.h +3 -3
  1497. data/src/core/load_balancing/oob_backend_metric_internal.h +8 -9
  1498. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +31 -26
  1499. data/src/core/load_balancing/outlier_detection/outlier_detection.h +3 -5
  1500. data/src/core/load_balancing/pick_first/pick_first.cc +28 -25
  1501. data/src/core/load_balancing/priority/priority.cc +12 -14
  1502. data/src/core/load_balancing/ring_hash/ring_hash.cc +13 -15
  1503. data/src/core/load_balancing/ring_hash/ring_hash.h +3 -4
  1504. data/src/core/load_balancing/rls/rls.cc +27 -29
  1505. data/src/core/load_balancing/round_robin/round_robin.cc +9 -15
  1506. data/src/core/load_balancing/subchannel_interface.h +13 -6
  1507. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.cc +4 -4
  1508. data/src/core/load_balancing/weighted_round_robin/static_stride_scheduler.h +2 -3
  1509. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +15 -19
  1510. data/src/core/load_balancing/weighted_target/weighted_target.cc +11 -13
  1511. data/src/core/load_balancing/xds/cds.cc +23 -20
  1512. data/src/core/load_balancing/xds/xds_cluster_impl.cc +42 -45
  1513. data/src/core/load_balancing/xds/xds_cluster_manager.cc +10 -12
  1514. data/src/core/load_balancing/xds/xds_override_host.cc +15 -17
  1515. data/src/core/load_balancing/xds/xds_override_host.h +3 -4
  1516. data/src/core/load_balancing/xds/xds_wrr_locality.cc +11 -12
  1517. data/src/core/plugin_registry/grpc_plugin_registry.cc +1 -7
  1518. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +3 -1
  1519. data/src/core/resolver/dns/c_ares/dns_resolver_ares.cc +13 -16
  1520. data/src/core/resolver/dns/c_ares/dns_resolver_ares.h +2 -3
  1521. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver.h +4 -6
  1522. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +2 -4
  1523. data/src/core/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +8 -11
  1524. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.cc +15 -19
  1525. data/src/core/resolver/dns/c_ares/grpc_ares_wrapper.h +3 -6
  1526. data/src/core/resolver/dns/dns_resolver_plugin.cc +4 -5
  1527. data/src/core/resolver/dns/dns_resolver_plugin.h +1 -1
  1528. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +9 -11
  1529. data/src/core/resolver/dns/event_engine/event_engine_client_channel_resolver.h +3 -4
  1530. data/src/core/resolver/dns/event_engine/service_config_helper.cc +3 -5
  1531. data/src/core/resolver/dns/event_engine/service_config_helper.h +2 -2
  1532. data/src/core/resolver/dns/native/dns_resolver.cc +10 -11
  1533. data/src/core/resolver/dns/native/dns_resolver.h +1 -1
  1534. data/src/core/resolver/endpoint_addresses.cc +1 -3
  1535. data/src/core/resolver/endpoint_addresses.h +2 -3
  1536. data/src/core/resolver/fake/fake_resolver.cc +7 -8
  1537. data/src/core/resolver/fake/fake_resolver.h +7 -8
  1538. data/src/core/resolver/google_c2p/google_c2p_resolver.cc +11 -12
  1539. data/src/core/resolver/polling_resolver.cc +6 -8
  1540. data/src/core/resolver/polling_resolver.h +7 -8
  1541. data/src/core/resolver/resolver.h +4 -5
  1542. data/src/core/resolver/resolver_factory.h +4 -5
  1543. data/src/core/resolver/resolver_registry.cc +2 -2
  1544. data/src/core/resolver/resolver_registry.h +4 -5
  1545. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +5 -6
  1546. data/src/core/resolver/xds/xds_config.cc +1 -2
  1547. data/src/core/resolver/xds/xds_config.h +1 -2
  1548. data/src/core/resolver/xds/xds_dependency_manager.cc +2 -5
  1549. data/src/core/resolver/xds/xds_dependency_manager.h +1 -2
  1550. data/src/core/resolver/xds/xds_resolver.cc +15 -17
  1551. data/src/core/resolver/xds/xds_resolver_attributes.h +2 -3
  1552. data/src/core/server/server.cc +97 -74
  1553. data/src/core/server/server.h +13 -16
  1554. data/src/core/server/server_call_tracer_filter.cc +11 -4
  1555. data/src/core/server/server_call_tracer_filter.h +1 -1
  1556. data/src/core/server/server_config_selector.h +5 -6
  1557. data/src/core/server/server_config_selector_filter.cc +8 -6
  1558. data/src/core/server/xds_channel_stack_modifier.cc +3 -3
  1559. data/src/core/server/xds_channel_stack_modifier.h +5 -6
  1560. data/src/core/server/xds_server_config_fetcher.cc +23 -24
  1561. data/src/core/service_config/service_config.h +3 -5
  1562. data/src/core/service_config/service_config_call_data.h +5 -6
  1563. data/src/core/service_config/service_config_channel_arg_filter.cc +8 -6
  1564. data/src/core/service_config/service_config_impl.cc +4 -6
  1565. data/src/core/service_config/service_config_impl.h +4 -6
  1566. data/src/core/service_config/service_config_parser.cc +1 -2
  1567. data/src/core/service_config/service_config_parser.h +2 -4
  1568. data/src/core/telemetry/call_tracer.cc +2 -3
  1569. data/src/core/telemetry/call_tracer.h +5 -6
  1570. data/src/core/telemetry/histogram_view.cc +3 -3
  1571. data/src/core/telemetry/histogram_view.h +1 -2
  1572. data/src/core/telemetry/metrics.cc +18 -16
  1573. data/src/core/telemetry/metrics.h +13 -10
  1574. data/src/core/telemetry/stats.cc +1 -2
  1575. data/src/core/telemetry/stats.h +2 -4
  1576. data/src/core/telemetry/stats_data.cc +114 -2
  1577. data/src/core/telemetry/stats_data.h +82 -4
  1578. data/src/core/telemetry/tcp_tracer.h +1 -2
  1579. data/src/core/tsi/alts/crypt/aes_gcm.cc +5 -8
  1580. data/src/core/tsi/alts/crypt/gsec.cc +2 -3
  1581. data/src/core/tsi/alts/crypt/gsec.h +3 -4
  1582. data/src/core/tsi/alts/frame_protector/alts_counter.cc +1 -2
  1583. data/src/core/tsi/alts/frame_protector/alts_counter.h +3 -4
  1584. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +1 -2
  1585. data/src/core/tsi/alts/frame_protector/alts_crypter.h +2 -3
  1586. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +4 -5
  1587. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +1 -2
  1588. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +1 -1
  1589. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +1 -1
  1590. data/src/core/tsi/alts/frame_protector/frame_handler.cc +4 -6
  1591. data/src/core/tsi/alts/frame_protector/frame_handler.h +1 -2
  1592. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +11 -12
  1593. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +2 -3
  1594. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +1 -1
  1595. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +19 -17
  1596. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -3
  1597. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -2
  1598. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +3 -3
  1599. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +3 -5
  1600. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +1 -2
  1601. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +2 -3
  1602. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +1 -2
  1603. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +3 -5
  1604. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +3 -4
  1605. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +1 -2
  1606. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +3 -5
  1607. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +1 -2
  1608. data/src/core/tsi/fake_transport_security.cc +4 -7
  1609. data/src/core/tsi/local_transport_security.cc +4 -6
  1610. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +4 -5
  1611. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +8 -10
  1612. data/src/core/tsi/ssl/session_cache/ssl_session.h +4 -5
  1613. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +4 -5
  1614. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +7 -8
  1615. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -4
  1616. data/src/core/tsi/ssl_transport_security.cc +29 -17
  1617. data/src/core/tsi/ssl_transport_security.h +6 -8
  1618. data/src/core/tsi/ssl_transport_security_utils.cc +1 -3
  1619. data/src/core/tsi/ssl_transport_security_utils.h +3 -5
  1620. data/src/core/tsi/ssl_types.h +1 -2
  1621. data/src/core/tsi/transport_security.cc +2 -3
  1622. data/src/core/tsi/transport_security.h +1 -2
  1623. data/src/core/tsi/transport_security_interface.h +3 -4
  1624. data/src/core/util/alloc.cc +2 -5
  1625. data/src/core/util/atm.cc +1 -2
  1626. data/src/core/{lib/gprpp → util}/atomic_utils.h +5 -5
  1627. data/src/core/{lib/avl → util}/avl.h +6 -7
  1628. data/src/core/{lib/backoff → util}/backoff.cc +3 -1
  1629. data/src/core/{lib/backoff → util}/backoff.h +4 -5
  1630. data/src/core/{lib/gprpp → util}/bitset.h +4 -5
  1631. data/src/core/{lib/gprpp → util}/chunked_vector.h +6 -7
  1632. data/src/core/{lib/gprpp → util}/construct_destruct.h +8 -7
  1633. data/src/core/{lib/gprpp → util}/cpp_impl_of.h +3 -3
  1634. data/src/core/{lib/gprpp → util}/crash.cc +2 -3
  1635. data/src/core/{lib/gprpp → util}/crash.h +5 -6
  1636. data/src/core/{lib/gprpp → util}/debug_location.h +5 -5
  1637. data/src/core/{lib/gprpp → util}/directory_reader.h +5 -5
  1638. data/src/core/{lib/gprpp → util}/down_cast.h +7 -7
  1639. data/src/core/{lib/gprpp → util}/dual_ref_counted.h +10 -11
  1640. data/src/core/{lib/gprpp → util}/dump_args.cc +1 -1
  1641. data/src/core/{lib/gprpp → util}/dump_args.h +12 -7
  1642. data/src/core/{lib/gprpp → util}/env.h +5 -5
  1643. data/src/core/{lib/debug → util}/event_log.cc +3 -3
  1644. data/src/core/{lib/debug → util}/event_log.h +6 -8
  1645. data/src/core/{lib/gprpp → util}/examine_stack.cc +1 -1
  1646. data/src/core/{lib/gprpp → util}/examine_stack.h +5 -5
  1647. data/src/core/{lib/gprpp → util}/fork.cc +5 -5
  1648. data/src/core/{lib/gprpp → util}/fork.h +7 -7
  1649. data/src/core/util/gcp_metadata_query.cc +8 -11
  1650. data/src/core/util/gcp_metadata_query.h +2 -3
  1651. data/src/core/{lib/iomgr → util}/gethostname.h +3 -3
  1652. data/src/core/{lib/iomgr → util}/gethostname_fallback.cc +1 -1
  1653. data/src/core/{lib/iomgr → util}/gethostname_host_name_max.cc +2 -3
  1654. data/src/core/{lib/iomgr → util}/gethostname_sysconf.cc +2 -3
  1655. data/src/core/{lib/gprpp → util}/glob.h +3 -3
  1656. data/src/core/util/gpr_time.cc +268 -0
  1657. data/src/core/{lib/iomgr → util}/grpc_if_nametoindex.h +4 -5
  1658. data/src/core/{lib/iomgr → util}/grpc_if_nametoindex_posix.cc +2 -3
  1659. data/src/core/{lib/iomgr → util}/grpc_if_nametoindex_unsupported.cc +2 -3
  1660. data/src/core/{lib/gprpp → util}/host_port.cc +2 -3
  1661. data/src/core/{lib/gprpp → util}/host_port.h +5 -5
  1662. data/src/core/util/http_client/format_request.cc +2 -5
  1663. data/src/core/util/http_client/format_request.h +1 -2
  1664. data/src/core/util/http_client/httpcli.cc +19 -15
  1665. data/src/core/util/http_client/httpcli.h +8 -11
  1666. data/src/core/util/http_client/httpcli_security_connector.cc +9 -12
  1667. data/src/core/util/http_client/httpcli_ssl_credentials.h +2 -3
  1668. data/src/core/util/http_client/parser.cc +2 -4
  1669. data/src/core/util/http_client/parser.h +1 -3
  1670. data/src/core/{lib/gprpp → util}/if_list.h +3 -3
  1671. data/src/core/util/iphone/cpu.cc +1 -2
  1672. data/src/core/util/json/json.h +1 -2
  1673. data/src/core/util/json/json_channel_args.h +0 -1
  1674. data/src/core/util/json/json_object_loader.cc +3 -4
  1675. data/src/core/util/json/json_object_loader.h +8 -9
  1676. data/src/core/util/json/json_reader.cc +2 -5
  1677. data/src/core/util/json/json_reader.h +0 -1
  1678. data/src/core/util/json/json_util.cc +4 -4
  1679. data/src/core/util/json/json_util.h +1 -2
  1680. data/src/core/util/json/json_writer.cc +1 -3
  1681. data/src/core/util/latent_see.cc +99 -69
  1682. data/src/core/util/latent_see.h +45 -20
  1683. data/src/core/util/linux/cpu.cc +4 -6
  1684. data/src/core/{lib/gprpp → util}/linux/env.cc +3 -3
  1685. data/src/core/{lib/gprpp → util}/load_file.cc +4 -5
  1686. data/src/core/{lib/gprpp → util}/load_file.h +5 -6
  1687. data/src/core/util/log.cc +10 -13
  1688. data/src/core/util/lru_cache.h +27 -9
  1689. data/src/core/{lib/gprpp → util}/manual_constructor.h +5 -6
  1690. data/src/core/{lib/gprpp → util}/match.h +6 -7
  1691. data/src/core/{lib/matchers → util}/matchers.cc +10 -3
  1692. data/src/core/{lib/matchers → util}/matchers.h +9 -5
  1693. data/src/core/{lib/gprpp → util}/memory.h +6 -6
  1694. data/src/core/{lib/gprpp → util}/mpscq.cc +1 -1
  1695. data/src/core/{lib/gprpp → util}/mpscq.h +6 -7
  1696. data/src/core/util/msys/tmpfile.cc +3 -4
  1697. data/src/core/{lib/gprpp → util}/no_destruct.h +6 -6
  1698. data/src/core/{lib/gprpp → util}/notification.h +6 -7
  1699. data/src/core/{lib/gprpp → util}/orphanable.h +9 -9
  1700. data/src/core/{lib/gprpp → util}/overload.h +5 -5
  1701. data/src/core/{lib/gprpp → util}/packed_table.h +5 -5
  1702. data/src/core/{lib/gprpp → util}/per_cpu.cc +1 -1
  1703. data/src/core/{lib/gprpp → util}/per_cpu.h +5 -6
  1704. data/src/core/util/posix/cpu.cc +3 -5
  1705. data/src/core/{lib/gprpp → util}/posix/directory_reader.cc +4 -4
  1706. data/src/core/{lib/gprpp → util}/posix/env.cc +1 -1
  1707. data/src/core/{lib/gprpp → util}/posix/stat.cc +4 -5
  1708. data/src/core/util/posix/string.cc +2 -3
  1709. data/src/core/util/posix/sync.cc +3 -5
  1710. data/src/core/{lib/gprpp → util}/posix/thd.cc +8 -11
  1711. data/src/core/util/posix/time.cc +4 -5
  1712. data/src/core/util/posix/tmpfile.cc +4 -6
  1713. data/src/core/{lib/backoff → util}/random_early_detection.cc +3 -3
  1714. data/src/core/{lib/backoff → util}/random_early_detection.h +4 -5
  1715. data/src/core/{lib/gprpp → util}/ref_counted.h +9 -10
  1716. data/src/core/{lib/gprpp → util}/ref_counted_ptr.h +6 -8
  1717. data/src/core/{lib/gprpp → util}/ref_counted_string.cc +3 -4
  1718. data/src/core/{lib/gprpp → util}/ref_counted_string.h +6 -8
  1719. data/src/core/{lib/gprpp → util}/single_set_ptr.h +5 -5
  1720. data/src/core/{lib/gprpp → util}/sorted_pack.h +6 -6
  1721. data/src/core/util/spinlock.h +1 -2
  1722. data/src/core/{lib/gprpp → util}/stat.h +4 -5
  1723. data/src/core/{lib/gprpp → util}/status_helper.cc +5 -7
  1724. data/src/core/{lib/gprpp → util}/status_helper.h +5 -7
  1725. data/src/core/{lib/gprpp → util}/strerror.cc +2 -3
  1726. data/src/core/{lib/gprpp → util}/strerror.h +5 -5
  1727. data/src/core/util/string.cc +6 -9
  1728. data/src/core/util/string.h +1 -3
  1729. data/src/core/util/sync.cc +3 -5
  1730. data/src/core/{lib/gprpp → util}/sync.h +7 -7
  1731. data/src/core/util/sync_abseil.cc +5 -7
  1732. data/src/core/{lib/gprpp → util}/table.h +6 -8
  1733. data/src/core/{lib/gprpp → util}/tchar.cc +1 -1
  1734. data/src/core/{lib/gprpp → util}/tchar.h +3 -3
  1735. data/src/core/{lib/gprpp → util}/thd.h +5 -6
  1736. data/src/core/util/time.cc +174 -204
  1737. data/src/core/{lib/gprpp → util}/time.h +16 -10
  1738. data/src/core/{lib/gprpp → util}/time_averaged_stats.cc +1 -1
  1739. data/src/core/{lib/gprpp → util}/time_averaged_stats.h +3 -3
  1740. data/src/core/util/time_precise.cc +3 -4
  1741. data/src/core/util/time_precise.h +0 -1
  1742. data/src/core/{lib/gprpp → util}/time_util.cc +3 -4
  1743. data/src/core/{lib/gprpp → util}/time_util.h +5 -5
  1744. data/src/core/util/tmpfile.h +0 -1
  1745. data/src/core/{lib/gprpp → util}/type_list.h +3 -3
  1746. data/src/core/{lib/gprpp → util}/unique_type_name.h +5 -6
  1747. data/src/core/{lib/uri/uri_parser.cc → util/uri.cc} +12 -7
  1748. data/src/core/{lib/uri/uri_parser.h → util/uri.h} +10 -6
  1749. data/src/core/{lib/gprpp → util}/uuid_v4.cc +3 -3
  1750. data/src/core/{lib/gprpp → util}/uuid_v4.h +4 -5
  1751. data/src/core/{lib/gprpp → util}/validation_errors.cc +2 -3
  1752. data/src/core/{lib/gprpp → util}/validation_errors.h +4 -5
  1753. data/src/core/util/windows/cpu.cc +1 -1
  1754. data/src/core/{lib/gprpp → util}/windows/directory_reader.cc +1 -1
  1755. data/src/core/{lib/gprpp → util}/windows/env.cc +2 -2
  1756. data/src/core/{lib/gprpp → util}/windows/stat.cc +3 -4
  1757. data/src/core/util/windows/string.cc +2 -3
  1758. data/src/core/util/windows/string_util.cc +5 -7
  1759. data/src/core/util/windows/sync.cc +2 -3
  1760. data/src/core/{lib/gprpp → util}/windows/thd.cc +6 -8
  1761. data/src/core/util/windows/time.cc +2 -4
  1762. data/src/core/util/windows/tmpfile.cc +4 -5
  1763. data/src/core/{lib/gprpp → util}/work_serializer.cc +7 -12
  1764. data/src/core/{lib/gprpp → util}/work_serializer.h +8 -9
  1765. data/src/core/{lib/gprpp → util}/xxhash_inline.h +3 -3
  1766. data/src/core/xds/grpc/certificate_provider_store.cc +3 -4
  1767. data/src/core/xds/grpc/certificate_provider_store.h +9 -10
  1768. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.cc +4 -5
  1769. data/src/core/xds/grpc/file_watcher_certificate_provider_factory.h +6 -7
  1770. data/src/core/xds/grpc/xds_audit_logger_registry.cc +4 -5
  1771. data/src/core/xds/grpc/xds_audit_logger_registry.h +3 -4
  1772. data/src/core/xds/grpc/xds_bootstrap_grpc.cc +4 -5
  1773. data/src/core/xds/grpc/xds_bootstrap_grpc.h +4 -4
  1774. data/src/core/xds/grpc/xds_certificate_provider.cc +2 -3
  1775. data/src/core/xds/grpc/xds_certificate_provider.h +8 -9
  1776. data/src/core/xds/grpc/xds_client_grpc.cc +63 -39
  1777. data/src/core/xds/grpc/xds_client_grpc.h +14 -8
  1778. data/src/core/xds/grpc/xds_cluster.cc +9 -4
  1779. data/src/core/xds/grpc/xds_cluster.h +30 -4
  1780. data/src/core/xds/grpc/xds_cluster_parser.cc +106 -26
  1781. data/src/core/xds/grpc/xds_cluster_parser.h +6 -2
  1782. data/src/core/xds/grpc/xds_cluster_specifier_plugin.cc +5 -7
  1783. data/src/core/xds/grpc/xds_cluster_specifier_plugin.h +5 -6
  1784. data/src/core/xds/grpc/xds_common_types.cc +1 -2
  1785. data/src/core/xds/grpc/xds_common_types.h +2 -3
  1786. data/src/core/xds/grpc/xds_common_types_parser.cc +45 -9
  1787. data/src/core/xds/grpc/xds_common_types_parser.h +8 -3
  1788. data/src/core/xds/grpc/xds_endpoint.h +7 -5
  1789. data/src/core/xds/grpc/xds_endpoint_parser.cc +45 -40
  1790. data/src/core/xds/grpc/xds_endpoint_parser.h +1 -2
  1791. data/src/core/xds/grpc/xds_health_status.h +0 -1
  1792. data/src/core/xds/grpc/xds_http_fault_filter.cc +5 -7
  1793. data/src/core/xds/grpc/xds_http_fault_filter.h +4 -5
  1794. data/src/core/xds/grpc/xds_http_filter.h +2 -3
  1795. data/src/core/xds/grpc/xds_http_filter_registry.cc +2 -3
  1796. data/src/core/xds/grpc/xds_http_filter_registry.h +2 -3
  1797. data/src/core/xds/grpc/xds_http_gcp_authn_filter.cc +5 -6
  1798. data/src/core/xds/grpc/xds_http_gcp_authn_filter.h +2 -3
  1799. data/src/core/xds/grpc/xds_http_rbac_filter.cc +42 -39
  1800. data/src/core/xds/grpc/xds_http_rbac_filter.h +4 -5
  1801. data/src/core/xds/grpc/xds_http_stateful_session_filter.cc +5 -6
  1802. data/src/core/xds/grpc/xds_http_stateful_session_filter.h +4 -5
  1803. data/src/core/xds/grpc/xds_lb_policy_registry.cc +5 -7
  1804. data/src/core/xds/grpc/xds_lb_policy_registry.h +4 -5
  1805. data/src/core/xds/grpc/xds_listener.cc +1 -2
  1806. data/src/core/xds/grpc/xds_listener.h +1 -2
  1807. data/src/core/xds/grpc/xds_listener_parser.cc +5 -8
  1808. data/src/core/xds/grpc/xds_listener_parser.h +1 -2
  1809. data/src/core/xds/grpc/xds_metadata.h +26 -3
  1810. data/src/core/xds/grpc/xds_metadata_parser.cc +51 -10
  1811. data/src/core/xds/grpc/xds_metadata_parser.h +1 -2
  1812. data/src/core/xds/grpc/xds_route_config.cc +3 -3
  1813. data/src/core/xds/grpc/xds_route_config.h +2 -3
  1814. data/src/core/xds/grpc/xds_route_config_parser.cc +11 -13
  1815. data/src/core/xds/grpc/xds_route_config_parser.h +4 -7
  1816. data/src/core/xds/grpc/xds_routing.cc +2 -4
  1817. data/src/core/xds/grpc/xds_routing.h +1 -3
  1818. data/src/core/xds/grpc/xds_server_grpc.cc +1 -2
  1819. data/src/core/xds/grpc/xds_server_grpc.h +2 -2
  1820. data/src/core/xds/grpc/xds_transport_grpc.cc +95 -50
  1821. data/src/core/xds/grpc/xds_transport_grpc.h +33 -22
  1822. data/src/core/xds/xds_client/lrs_client.cc +1292 -0
  1823. data/src/core/xds/xds_client/lrs_client.h +394 -0
  1824. data/src/core/xds/xds_client/xds_api.cc +31 -245
  1825. data/src/core/xds/xds_client/xds_api.h +13 -36
  1826. data/src/core/xds/xds_client/xds_backend_metric_propagation.cc +63 -0
  1827. data/src/core/xds/xds_client/xds_backend_metric_propagation.h +59 -0
  1828. data/src/core/xds/xds_client/xds_bootstrap.cc +2 -3
  1829. data/src/core/xds/xds_client/xds_bootstrap.h +2 -2
  1830. data/src/core/xds/xds_client/xds_client.cc +57 -595
  1831. data/src/core/xds/xds_client/xds_client.h +33 -86
  1832. data/src/core/xds/xds_client/xds_locality.h +102 -0
  1833. data/src/core/xds/xds_client/xds_metrics.h +2 -2
  1834. data/src/core/xds/xds_client/xds_resource_type.h +4 -5
  1835. data/src/core/xds/xds_client/xds_resource_type_impl.h +3 -4
  1836. data/src/core/xds/xds_client/xds_transport.h +29 -14
  1837. data/src/ruby/ext/grpc/extconf.rb +1 -1
  1838. data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -3
  1839. data/src/ruby/ext/grpc/rb_call.c +5 -5
  1840. data/src/ruby/ext/grpc/rb_call_credentials.c +5 -6
  1841. data/src/ruby/ext/grpc/rb_channel.c +6 -7
  1842. data/src/ruby/ext/grpc/rb_channel_args.c +3 -3
  1843. data/src/ruby/ext/grpc/rb_channel_credentials.c +5 -6
  1844. data/src/ruby/ext/grpc/rb_channel_credentials.h +1 -2
  1845. data/src/ruby/ext/grpc/rb_completion_queue.c +3 -4
  1846. data/src/ruby/ext/grpc/rb_compression_options.c +6 -7
  1847. data/src/ruby/ext/grpc/rb_event_thread.c +4 -5
  1848. data/src/ruby/ext/grpc/rb_grpc.c +3 -4
  1849. data/src/ruby/ext/grpc/rb_grpc.h +2 -3
  1850. data/src/ruby/ext/grpc/rb_server.c +6 -6
  1851. data/src/ruby/ext/grpc/rb_server_credentials.c +3 -3
  1852. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -2
  1853. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +5 -6
  1854. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +1 -2
  1855. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +4 -4
  1856. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +1 -2
  1857. data/src/ruby/lib/grpc/version.rb +1 -1
  1858. data/src/ruby/spec/generic/client_stub_spec.rb +20 -20
  1859. data/third_party/abseil-cpp/absl/algorithm/container.h +57 -18
  1860. data/third_party/abseil-cpp/absl/base/attributes.h +84 -0
  1861. data/third_party/abseil-cpp/absl/base/config.h +32 -51
  1862. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +0 -16
  1863. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +3 -1
  1864. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +13 -3
  1865. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -12
  1866. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +4 -4
  1867. data/third_party/abseil-cpp/absl/base/macros.h +48 -0
  1868. data/third_party/abseil-cpp/absl/base/no_destructor.h +35 -40
  1869. data/third_party/abseil-cpp/absl/base/nullability.h +33 -7
  1870. data/third_party/abseil-cpp/absl/base/optimization.h +11 -0
  1871. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  1872. data/third_party/abseil-cpp/absl/base/prefetch.h +1 -1
  1873. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +68 -12
  1874. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +60 -6
  1875. data/third_party/abseil-cpp/absl/container/hash_container_defaults.h +45 -0
  1876. data/third_party/abseil-cpp/absl/container/inlined_vector.h +13 -0
  1877. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +20 -11
  1878. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +15 -16
  1879. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +34 -1
  1880. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +68 -1
  1881. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +50 -0
  1882. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +22 -7
  1883. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +26 -8
  1884. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +39 -35
  1885. data/third_party/abseil-cpp/absl/container/internal/layout.h +190 -74
  1886. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +8 -6
  1887. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +334 -71
  1888. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1299 -458
  1889. data/third_party/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +19 -17
  1890. data/third_party/abseil-cpp/absl/crc/internal/crc_cord_state.cc +4 -3
  1891. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +2 -1
  1892. data/third_party/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +12 -8
  1893. data/third_party/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +1 -1
  1894. data/third_party/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +11 -7
  1895. data/third_party/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +18 -17
  1896. data/third_party/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence.h +126 -0
  1897. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +258 -0
  1898. data/third_party/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +55 -0
  1899. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1057 -86
  1900. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +3 -0
  1901. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.cc +925 -0
  1902. data/third_party/abseil-cpp/absl/debugging/internal/demangle_rust.h +42 -0
  1903. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +43 -16
  1904. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +8 -7
  1905. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +10 -7
  1906. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.cc +70 -0
  1907. data/third_party/abseil-cpp/absl/debugging/internal/utf8_for_code_point.h +47 -0
  1908. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +11 -0
  1909. data/third_party/abseil-cpp/absl/flags/flag.h +2 -0
  1910. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +117 -30
  1911. data/third_party/abseil-cpp/absl/flags/internal/flag.h +192 -30
  1912. data/third_party/abseil-cpp/absl/flags/reflection.cc +10 -0
  1913. data/third_party/abseil-cpp/absl/functional/any_invocable.h +13 -3
  1914. data/third_party/abseil-cpp/absl/functional/bind_front.h +3 -2
  1915. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +7 -7
  1916. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +9 -9
  1917. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +1 -1
  1918. data/third_party/abseil-cpp/absl/hash/internal/hash.h +13 -3
  1919. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +60 -28
  1920. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +4 -0
  1921. data/third_party/abseil-cpp/absl/log/absl_vlog_is_on.h +3 -3
  1922. data/third_party/abseil-cpp/absl/log/globals.h +28 -15
  1923. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +20 -0
  1924. data/third_party/abseil-cpp/absl/log/internal/check_op.h +63 -21
  1925. data/third_party/abseil-cpp/absl/log/internal/conditions.h +2 -2
  1926. data/third_party/abseil-cpp/absl/log/internal/log_impl.h +23 -23
  1927. data/third_party/abseil-cpp/absl/log/internal/log_message.cc +104 -47
  1928. data/third_party/abseil-cpp/absl/log/internal/log_message.h +23 -4
  1929. data/third_party/abseil-cpp/absl/log/internal/nullstream.h +1 -10
  1930. data/third_party/abseil-cpp/absl/log/internal/strip.h +36 -0
  1931. data/third_party/abseil-cpp/absl/log/log.h +5 -1
  1932. data/third_party/abseil-cpp/absl/log/log_sink.h +11 -4
  1933. data/third_party/abseil-cpp/absl/log/vlog_is_on.h +3 -3
  1934. data/third_party/abseil-cpp/absl/meta/type_traits.h +138 -42
  1935. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -3
  1936. data/third_party/abseil-cpp/absl/numeric/int128.h +35 -5
  1937. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +14 -0
  1938. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +18 -0
  1939. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +6 -2
  1940. data/third_party/abseil-cpp/absl/random/beta_distribution.h +8 -8
  1941. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +9 -7
  1942. data/third_party/abseil-cpp/absl/random/distributions.h +11 -11
  1943. data/third_party/abseil-cpp/absl/random/seed_sequences.h +2 -0
  1944. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +61 -2
  1945. data/third_party/abseil-cpp/absl/status/status.cc +0 -4
  1946. data/third_party/abseil-cpp/absl/status/status.h +4 -4
  1947. data/third_party/abseil-cpp/absl/status/statusor.h +108 -142
  1948. data/third_party/abseil-cpp/absl/strings/ascii.cc +32 -71
  1949. data/third_party/abseil-cpp/absl/strings/cord.cc +20 -15
  1950. data/third_party/abseil-cpp/absl/strings/cord.h +68 -7
  1951. data/third_party/abseil-cpp/absl/strings/escaping.cc +96 -21
  1952. data/third_party/abseil-cpp/absl/strings/escaping.h +25 -8
  1953. data/third_party/abseil-cpp/absl/strings/has_absl_stringify.h +1 -0
  1954. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +10 -0
  1955. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +29 -9
  1956. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +2 -2
  1957. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.cc +19 -13
  1958. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.h +23 -13
  1959. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +24 -24
  1960. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +12 -7
  1961. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.h +9 -4
  1962. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +5 -2
  1963. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +23 -2
  1964. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +5 -1
  1965. data/third_party/abseil-cpp/absl/strings/numbers.cc +107 -333
  1966. data/third_party/abseil-cpp/absl/strings/numbers.h +12 -151
  1967. data/third_party/abseil-cpp/absl/strings/str_cat.cc +49 -142
  1968. data/third_party/abseil-cpp/absl/strings/str_cat.h +70 -85
  1969. data/third_party/abseil-cpp/absl/strings/str_format.h +1 -1
  1970. data/third_party/abseil-cpp/absl/strings/str_join.h +19 -5
  1971. data/third_party/abseil-cpp/absl/strings/str_split.h +2 -2
  1972. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  1973. data/third_party/abseil-cpp/absl/strings/substitute.cc +4 -0
  1974. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +11 -2
  1975. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +5 -0
  1976. data/third_party/abseil-cpp/absl/synchronization/mutex.h +5 -4
  1977. data/third_party/abseil-cpp/absl/time/civil_time.h +2 -2
  1978. data/third_party/abseil-cpp/absl/time/clock.cc +15 -1
  1979. data/third_party/abseil-cpp/absl/time/duration.cc +58 -53
  1980. data/third_party/abseil-cpp/absl/time/format.cc +2 -1
  1981. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +1 -1
  1982. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -29
  1983. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +3 -3
  1984. data/third_party/abseil-cpp/absl/time/time.h +73 -29
  1985. data/third_party/abseil-cpp/absl/types/compare.h +505 -0
  1986. data/third_party/abseil-cpp/absl/types/internal/optional.h +2 -2
  1987. data/third_party/abseil-cpp/absl/types/internal/variant.h +55 -67
  1988. data/third_party/abseil-cpp/absl/types/optional.h +15 -18
  1989. data/third_party/abseil-cpp/absl/types/span.h +3 -2
  1990. data/third_party/abseil-cpp/absl/types/variant.h +19 -24
  1991. data/third_party/abseil-cpp/absl/utility/utility.h +3 -41
  1992. data/third_party/upb/upb/json/decode.c +59 -13
  1993. data/third_party/upb/upb/json/decode.h +26 -3
  1994. data/third_party/upb/upb/json/encode.c +2 -2
  1995. data/third_party/upb/upb/lex/round_trip.c +10 -0
  1996. data/third_party/upb/upb/mem/arena.c +13 -2
  1997. data/third_party/upb/upb/mem/arena.h +9 -0
  1998. data/third_party/upb/upb/mem/arena.hpp +5 -1
  1999. data/third_party/upb/upb/message/accessors.c +2 -4
  2000. data/third_party/upb/upb/message/accessors.h +178 -379
  2001. data/third_party/upb/upb/message/copy.c +11 -7
  2002. data/third_party/upb/upb/message/internal/accessors.h +578 -26
  2003. data/third_party/upb/upb/message/internal/extension.c +1 -0
  2004. data/third_party/upb/upb/message/internal/message.c +13 -14
  2005. data/third_party/upb/upb/message/internal/message.h +8 -7
  2006. data/third_party/upb/upb/message/merge.c +38 -0
  2007. data/third_party/upb/upb/message/merge.h +26 -0
  2008. data/third_party/upb/upb/message/message.h +6 -10
  2009. data/third_party/upb/upb/message/value.h +26 -0
  2010. data/third_party/upb/upb/mini_descriptor/decode.c +7 -2
  2011. data/third_party/upb/upb/mini_descriptor/link.c +7 -3
  2012. data/third_party/upb/upb/mini_table/extension_registry.c +18 -0
  2013. data/third_party/upb/upb/mini_table/extension_registry.h +17 -0
  2014. data/third_party/upb/upb/mini_table/internal/extension.h +9 -0
  2015. data/third_party/upb/upb/mini_table/internal/message.c +21 -1
  2016. data/third_party/upb/upb/mini_table/internal/message.h +40 -20
  2017. data/third_party/upb/upb/mini_table/internal/sub.h +5 -0
  2018. data/third_party/upb/upb/mini_table/message.h +11 -1
  2019. data/third_party/upb/upb/port/def.inc +99 -9
  2020. data/third_party/upb/upb/port/undef.inc +7 -0
  2021. data/third_party/upb/upb/reflection/common.h +1 -11
  2022. data/third_party/upb/upb/reflection/def.hpp +8 -0
  2023. data/third_party/upb/upb/reflection/descriptor_bootstrap.h +19 -0
  2024. data/third_party/upb/upb/reflection/field_def.c +11 -22
  2025. data/third_party/upb/upb/reflection/field_def.h +1 -0
  2026. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  2027. data/third_party/upb/upb/reflection/message.c +8 -3
  2028. data/third_party/upb/upb/reflection/message.h +2 -2
  2029. data/third_party/upb/upb/text/encode.c +51 -394
  2030. data/third_party/upb/upb/text/encode.h +1 -11
  2031. data/third_party/upb/upb/text/internal/encode.c +180 -0
  2032. data/third_party/upb/upb/text/internal/encode.h +240 -0
  2033. data/third_party/upb/upb/text/options.h +22 -0
  2034. data/third_party/upb/upb/wire/decode.c +71 -39
  2035. data/third_party/upb/upb/wire/decode.h +4 -1
  2036. data/third_party/upb/upb/wire/encode.c +41 -18
  2037. data/third_party/upb/upb/wire/encode.h +3 -0
  2038. data/third_party/upb/upb/wire/internal/decode_fast.c +3 -0
  2039. metadata +142 -109
  2040. data/src/core/lib/gprpp/time.cc +0 -241
  2041. data/src/core/resolver/binder/binder_resolver.cc +0 -153
  2042. data/src/core/xds/xds_client/xds_client_stats.cc +0 -164
  2043. data/src/core/xds/xds_client/xds_client_stats.h +0 -258
  2044. data/third_party/abseil-cpp/absl/strings/internal/has_absl_stringify.h +0 -44
  2045. /data/src/core/{lib/gprpp → util}/glob.cc +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