grpc 1.45.0 → 1.47.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of grpc might be problematic. Click here for more details.

Files changed (859) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +69 -110
  3. data/include/grpc/event_engine/event_engine.h +42 -7
  4. data/include/grpc/event_engine/memory_allocator.h +0 -15
  5. data/include/grpc/event_engine/port.h +1 -1
  6. data/include/grpc/event_engine/slice.h +286 -0
  7. data/include/grpc/event_engine/slice_buffer.h +112 -0
  8. data/include/grpc/grpc_security.h +11 -0
  9. data/include/grpc/impl/codegen/grpc_types.h +7 -13
  10. data/include/grpc/impl/codegen/port_platform.h +100 -36
  11. data/include/grpc/impl/codegen/slice.h +1 -1
  12. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +297 -0
  13. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +125 -0
  14. data/src/core/ext/filters/{client_idle → channel_idle}/idle_filter_state.cc +1 -1
  15. data/src/core/ext/filters/{client_idle → channel_idle}/idle_filter_state.h +3 -3
  16. data/src/core/ext/filters/client_channel/backend_metric.cc +17 -12
  17. data/src/core/ext/filters/client_channel/backend_metric.h +19 -9
  18. data/src/core/ext/filters/client_channel/backup_poller.cc +5 -5
  19. data/src/core/ext/filters/client_channel/backup_poller.h +2 -4
  20. data/src/core/ext/filters/client_channel/channel_connectivity.cc +42 -20
  21. data/src/core/ext/filters/client_channel/client_channel.cc +223 -113
  22. data/src/core/ext/filters/client_channel/client_channel.h +28 -6
  23. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +3 -5
  24. data/src/core/ext/filters/client_channel/client_channel_channelz.h +12 -2
  25. data/src/core/ext/filters/client_channel/client_channel_factory.cc +5 -0
  26. data/src/core/ext/filters/client_channel/client_channel_factory.h +8 -0
  27. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +4 -13
  28. data/src/core/ext/filters/client_channel/config_selector.cc +1 -0
  29. data/src/core/ext/filters/client_channel/config_selector.h +7 -5
  30. data/src/core/ext/filters/client_channel/connector.h +8 -2
  31. data/src/core/ext/filters/client_channel/dynamic_filters.cc +13 -2
  32. data/src/core/ext/filters/client_channel/dynamic_filters.h +11 -1
  33. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +2 -0
  34. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +3 -0
  35. data/src/core/ext/filters/client_channel/health/health_check_client.cc +138 -582
  36. data/src/core/ext/filters/client_channel/health/health_check_client.h +26 -160
  37. data/src/core/ext/filters/client_channel/http_proxy.cc +98 -112
  38. data/src/core/ext/filters/client_channel/http_proxy.h +20 -0
  39. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +6 -2
  40. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +1 -0
  41. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +49 -0
  42. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +12 -0
  43. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +5 -0
  44. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +9 -3
  45. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +59 -19
  46. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +4 -0
  47. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +6 -0
  48. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +10 -1
  49. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +6 -3
  50. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +408 -0
  51. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +57 -0
  52. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +1038 -0
  53. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +54 -0
  54. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +60 -52
  55. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +277 -195
  56. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +158 -101
  57. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +2 -0
  58. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +46 -20
  59. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +182 -171
  60. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +39 -36
  61. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +117 -63
  62. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +142 -63
  63. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +6 -0
  64. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +30 -4
  65. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +37 -10
  66. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +300 -291
  67. data/src/core/ext/filters/client_channel/lb_policy.cc +4 -2
  68. data/src/core/ext/filters/client_channel/lb_policy.h +18 -24
  69. data/src/core/ext/filters/client_channel/lb_policy_factory.h +2 -0
  70. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +8 -1
  71. data/src/core/ext/filters/client_channel/lb_policy_registry.h +6 -1
  72. data/src/core/ext/filters/client_channel/local_subchannel_pool.cc +4 -0
  73. data/src/core/ext/filters/client_channel/local_subchannel_pool.h +1 -0
  74. data/src/core/ext/filters/client_channel/proxy_mapper.h +1 -1
  75. data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +2 -0
  76. data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +5 -0
  77. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +23 -5
  78. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +226 -300
  79. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +8 -1
  80. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +10 -8
  81. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +1 -1
  82. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +26 -9
  83. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +13 -4
  84. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +2 -1
  85. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.cc +2 -0
  86. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.h +2 -1
  87. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +73 -220
  88. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +13 -14
  89. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +5 -2
  90. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +59 -13
  91. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +213 -0
  92. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +113 -0
  93. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +15 -11
  94. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +182 -79
  95. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +5 -11
  96. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +11 -5
  97. data/src/core/ext/filters/client_channel/retry_filter.cc +60 -5
  98. data/src/core/ext/filters/client_channel/retry_service_config.cc +8 -9
  99. data/src/core/ext/filters/client_channel/retry_service_config.h +10 -1
  100. data/src/core/ext/filters/client_channel/retry_throttle.cc +1 -8
  101. data/src/core/ext/filters/client_channel/retry_throttle.h +7 -1
  102. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +22 -5
  103. data/src/core/ext/filters/client_channel/subchannel.cc +161 -165
  104. data/src/core/ext/filters/client_channel/subchannel.h +80 -20
  105. data/src/core/ext/filters/client_channel/subchannel_interface.h +41 -23
  106. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +38 -0
  107. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +12 -2
  108. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +6 -3
  109. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +558 -0
  110. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +226 -0
  111. data/src/core/ext/filters/deadline/deadline_filter.cc +6 -2
  112. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +123 -366
  113. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +24 -1
  114. data/src/core/ext/filters/http/client/http_client_filter.cc +87 -458
  115. data/src/core/ext/filters/http/client/http_client_filter.h +27 -4
  116. data/src/core/ext/filters/http/client_authority_filter.cc +21 -31
  117. data/src/core/ext/filters/http/client_authority_filter.h +6 -5
  118. data/src/core/ext/filters/http/http_filters_plugin.cc +16 -14
  119. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +1 -0
  120. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +3 -1
  121. data/src/core/ext/filters/http/server/http_server_filter.cc +80 -361
  122. data/src/core/ext/filters/http/server/http_server_filter.h +31 -2
  123. data/src/core/ext/filters/message_size/message_size_filter.cc +20 -26
  124. data/src/core/ext/filters/message_size/message_size_filter.h +2 -2
  125. data/src/core/ext/filters/rbac/rbac_filter.cc +1 -0
  126. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +2 -8
  127. data/src/core/ext/filters/server_config_selector/server_config_selector.h +2 -2
  128. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +73 -201
  129. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +102 -135
  130. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +9 -7
  131. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +49 -19
  132. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -0
  133. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +3 -3
  134. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -1
  135. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +1 -0
  136. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +205 -45
  137. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +5 -0
  138. data/src/core/ext/transport/chttp2/transport/context_list.cc +4 -0
  139. data/src/core/ext/transport/chttp2/transport/context_list.h +4 -1
  140. data/src/core/ext/transport/chttp2/transport/flow_control.cc +6 -2
  141. data/src/core/ext/transport/chttp2/transport/flow_control.h +6 -2
  142. data/src/core/ext/transport/chttp2/transport/frame.h +0 -4
  143. data/src/core/ext/transport/chttp2/transport/frame_data.cc +7 -1
  144. data/src/core/ext/transport/chttp2/transport/frame_data.h +4 -1
  145. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +3 -0
  146. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +3 -1
  147. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +5 -0
  148. data/src/core/ext/transport/chttp2/transport/frame_ping.h +3 -0
  149. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +6 -2
  150. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +3 -0
  151. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +14 -3
  152. data/src/core/ext/transport/chttp2/transport/frame_settings.h +4 -0
  153. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +4 -1
  154. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +3 -0
  155. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +13 -15
  156. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +15 -2
  157. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +3 -0
  158. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +3 -0
  159. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +25 -7
  160. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +8 -1
  161. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +55 -37
  162. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +38 -21
  163. data/src/core/ext/transport/chttp2/transport/http2_settings.h +0 -1
  164. data/src/core/ext/transport/chttp2/transport/internal.h +28 -5
  165. data/src/core/ext/transport/chttp2/transport/parsing.cc +35 -6
  166. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +13 -9
  167. data/src/core/ext/transport/chttp2/transport/stream_map.cc +1 -1
  168. data/src/core/ext/transport/chttp2/transport/stream_map.h +1 -0
  169. data/src/core/ext/transport/chttp2/transport/varint.h +2 -0
  170. data/src/core/ext/transport/chttp2/transport/writing.cc +62 -15
  171. data/src/core/ext/transport/inproc/inproc_transport.cc +8 -5
  172. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +27 -24
  173. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +143 -63
  174. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +37 -35
  175. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +177 -77
  176. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +115 -111
  177. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +547 -207
  178. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +5 -5
  179. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +26 -13
  180. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +5 -5
  181. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +23 -9
  182. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +7 -7
  183. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +18 -0
  184. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +4 -4
  185. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +13 -4
  186. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +4 -4
  187. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +9 -0
  188. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +49 -46
  189. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +217 -78
  190. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +3 -3
  191. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +10 -2
  192. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +12 -12
  193. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +40 -8
  194. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +5 -5
  195. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +20 -2
  196. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +55 -55
  197. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +289 -110
  198. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +133 -125
  199. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +656 -267
  200. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +24 -18
  201. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +96 -23
  202. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +185 -173
  203. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +860 -309
  204. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +3 -3
  205. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +10 -2
  206. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +44 -24
  207. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +165 -40
  208. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +72 -63
  209. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +433 -174
  210. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +33 -31
  211. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +154 -52
  212. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +5 -4
  213. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +14 -4
  214. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +89 -89
  215. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +460 -166
  216. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +76 -33
  217. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +379 -69
  218. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +2 -2
  219. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +14 -6
  220. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +5 -25
  221. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +10 -91
  222. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +5 -5
  223. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +26 -13
  224. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +70 -68
  225. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +369 -131
  226. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +94 -65
  227. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +447 -161
  228. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +4 -4
  229. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +27 -11
  230. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +104 -85
  231. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +378 -113
  232. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +2 -2
  233. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +3 -0
  234. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +6 -6
  235. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +30 -13
  236. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +7 -7
  237. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +43 -16
  238. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +8 -8
  239. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +58 -24
  240. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +4 -4
  241. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +14 -4
  242. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +18 -18
  243. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +100 -43
  244. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +31 -30
  245. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +171 -71
  246. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +32 -32
  247. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +196 -95
  248. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +2 -2
  249. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +7 -2
  250. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +53 -46
  251. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +284 -129
  252. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +56 -50
  253. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +337 -146
  254. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +13 -11
  255. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +49 -14
  256. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +4 -4
  257. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +14 -4
  258. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +5 -5
  259. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +20 -4
  260. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +33 -32
  261. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +205 -86
  262. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +34 -34
  263. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +175 -74
  264. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +56 -52
  265. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +370 -146
  266. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +27 -23
  267. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +173 -74
  268. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +362 -341
  269. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +2056 -845
  270. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +11 -11
  271. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +49 -16
  272. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +56 -50
  273. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +293 -111
  274. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +3 -3
  275. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +6 -0
  276. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +3 -3
  277. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +10 -2
  278. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +5 -5
  279. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +26 -10
  280. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +5 -5
  281. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +27 -12
  282. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +17 -16
  283. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +83 -36
  284. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +2 -2
  285. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +7 -2
  286. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +8 -8
  287. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +46 -17
  288. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +9 -9
  289. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +38 -12
  290. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +7 -7
  291. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +30 -10
  292. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +2 -2
  293. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +10 -6
  294. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +15 -15
  295. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +71 -28
  296. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +25 -25
  297. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +149 -65
  298. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +8 -7
  299. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +30 -12
  300. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +9 -9
  301. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +42 -15
  302. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +173 -144
  303. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +898 -323
  304. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +51 -45
  305. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +261 -116
  306. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +13 -13
  307. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +70 -25
  308. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +80 -55
  309. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +410 -124
  310. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +5 -5
  311. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +23 -9
  312. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +1 -1
  313. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +44 -44
  314. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +261 -122
  315. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +8 -8
  316. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +47 -21
  317. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +32 -32
  318. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +175 -66
  319. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +4 -4
  320. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +17 -6
  321. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +8 -8
  322. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +38 -17
  323. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +8 -8
  324. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +12 -0
  325. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +7 -7
  326. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +43 -18
  327. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +3 -3
  328. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +20 -9
  329. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +3 -3
  330. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +24 -9
  331. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +2 -2
  332. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +14 -6
  333. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +8 -8
  334. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +40 -16
  335. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +9 -9
  336. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +70 -25
  337. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +5 -5
  338. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +37 -18
  339. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +12 -12
  340. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +81 -30
  341. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +16 -16
  342. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +76 -30
  343. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +20 -20
  344. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +90 -30
  345. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +7 -7
  346. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +28 -10
  347. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +2 -2
  348. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +3 -0
  349. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +5 -5
  350. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +13 -4
  351. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +9 -9
  352. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +18 -0
  353. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +4 -4
  354. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +9 -0
  355. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +5 -5
  356. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +17 -4
  357. data/src/core/ext/upb-generated/google/api/annotations.upb.c +3 -3
  358. data/src/core/ext/upb-generated/google/api/annotations.upb.h +17 -2
  359. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +70 -66
  360. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +410 -162
  361. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +80 -74
  362. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +440 -158
  363. data/src/core/ext/upb-generated/google/api/http.upb.c +17 -17
  364. data/src/core/ext/upb-generated/google/api/http.upb.h +116 -43
  365. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +4 -4
  366. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +19 -7
  367. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +3 -3
  368. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +6 -0
  369. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +163 -162
  370. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +1157 -435
  371. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +3 -3
  372. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +10 -4
  373. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -1
  374. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +15 -15
  375. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +108 -40
  376. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +3 -3
  377. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +10 -4
  378. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +18 -18
  379. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +27 -0
  380. data/src/core/ext/upb-generated/google/rpc/status.upb.c +4 -4
  381. data/src/core/ext/upb-generated/google/rpc/status.upb.h +19 -7
  382. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +15 -15
  383. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +65 -22
  384. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +12 -12
  385. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +49 -12
  386. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +69 -65
  387. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +364 -149
  388. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +8 -7
  389. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +20 -4
  390. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +4 -4
  391. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +6 -0
  392. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +31 -31
  393. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +150 -58
  394. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +11 -11
  395. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +51 -18
  396. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +175 -0
  397. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +764 -0
  398. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +22 -22
  399. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +97 -10
  400. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +6 -6
  401. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +23 -2
  402. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +3 -3
  403. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +10 -2
  404. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +6 -6
  405. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +27 -6
  406. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +5 -5
  407. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +20 -2
  408. data/src/core/ext/upb-generated/validate/validate.upb.c +261 -250
  409. data/src/core/ext/upb-generated/validate/validate.upb.h +1836 -663
  410. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +22 -22
  411. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +97 -10
  412. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +6 -6
  413. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +23 -2
  414. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +3 -3
  415. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +10 -2
  416. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +18 -18
  417. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +70 -10
  418. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +5 -5
  419. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +20 -2
  420. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +2 -2
  421. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +3 -0
  422. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +8 -8
  423. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +38 -12
  424. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +5 -5
  425. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +27 -10
  426. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +3 -3
  427. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +10 -2
  428. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +5 -5
  429. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +21 -8
  430. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +10 -10
  431. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +71 -30
  432. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +5 -5
  433. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +16 -2
  434. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +12 -12
  435. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +69 -26
  436. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +47 -0
  437. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +109 -0
  438. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +43 -39
  439. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +255 -103
  440. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +4 -4
  441. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +19 -8
  442. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +9 -9
  443. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +70 -25
  444. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +3 -3
  445. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +10 -2
  446. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +50 -46
  447. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +195 -185
  448. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +16 -12
  449. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +129 -94
  450. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +10 -0
  451. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +18 -33
  452. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +0 -5
  453. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +163 -155
  454. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +5 -0
  455. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +141 -138
  456. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +26 -20
  457. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +738 -730
  458. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +271 -251
  459. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -0
  460. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +207 -193
  461. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +5 -0
  462. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +99 -0
  463. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +75 -0
  464. data/src/core/ext/xds/certificate_provider_store.cc +10 -0
  465. data/src/core/ext/xds/certificate_provider_store.h +9 -0
  466. data/src/core/ext/xds/xds_api.cc +20 -0
  467. data/src/core/ext/xds/xds_bootstrap.cc +2 -2
  468. data/src/core/ext/xds/xds_bootstrap.h +2 -0
  469. data/src/core/ext/xds/xds_certificate_provider.cc +5 -0
  470. data/src/core/ext/xds/xds_certificate_provider.h +8 -0
  471. data/src/core/ext/xds/xds_channel_stack_modifier.cc +5 -5
  472. data/src/core/ext/xds/xds_client.cc +125 -109
  473. data/src/core/ext/xds/xds_client.h +13 -5
  474. data/src/core/ext/xds/xds_cluster.cc +106 -16
  475. data/src/core/ext/xds/xds_cluster.h +3 -0
  476. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +142 -0
  477. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +79 -0
  478. data/src/core/ext/xds/xds_common_types.cc +9 -9
  479. data/src/core/ext/xds/xds_common_types.h +3 -3
  480. data/src/core/ext/xds/xds_endpoint.cc +12 -5
  481. data/src/core/ext/xds/xds_http_fault_filter.cc +4 -4
  482. data/src/core/ext/xds/xds_listener.cc +20 -10
  483. data/src/core/ext/xds/xds_route_config.cc +162 -25
  484. data/src/core/ext/xds/xds_route_config.h +13 -10
  485. data/src/core/ext/xds/xds_server_config_fetcher.cc +19 -23
  486. data/src/core/lib/address_utils/sockaddr_utils.cc +56 -23
  487. data/src/core/lib/address_utils/sockaddr_utils.h +7 -4
  488. data/src/core/lib/avl/avl.h +71 -6
  489. data/src/core/lib/channel/call_finalization.h +4 -0
  490. data/src/core/lib/channel/call_tracer.h +12 -3
  491. data/src/core/lib/channel/channel_args.cc +179 -81
  492. data/src/core/lib/channel/channel_args.h +242 -11
  493. data/src/core/lib/channel/channel_args_preconditioning.cc +5 -11
  494. data/src/core/lib/channel/channel_args_preconditioning.h +4 -4
  495. data/src/core/lib/channel/channel_stack.cc +41 -3
  496. data/src/core/lib/channel/channel_stack.h +51 -8
  497. data/src/core/lib/channel/channel_stack_builder.cc +9 -84
  498. data/src/core/lib/channel/channel_stack_builder.h +35 -26
  499. data/src/core/lib/channel/channel_stack_builder_impl.cc +97 -0
  500. data/src/core/lib/channel/channel_stack_builder_impl.h +45 -0
  501. data/src/core/lib/channel/channel_trace.cc +8 -13
  502. data/src/core/lib/channel/channel_trace.h +6 -3
  503. data/src/core/lib/channel/channelz.cc +8 -13
  504. data/src/core/lib/channel/channelz.h +13 -4
  505. data/src/core/lib/channel/channelz_registry.cc +7 -14
  506. data/src/core/lib/channel/channelz_registry.h +10 -9
  507. data/src/core/lib/channel/connected_channel.cc +21 -31
  508. data/src/core/lib/channel/connected_channel.h +2 -0
  509. data/src/core/lib/channel/promise_based_filter.cc +848 -260
  510. data/src/core/lib/channel/promise_based_filter.h +215 -68
  511. data/src/core/lib/channel/status_util.cc +2 -0
  512. data/src/core/lib/channel/status_util.h +0 -3
  513. data/src/core/lib/compression/compression_internal.cc +46 -17
  514. data/src/core/lib/compression/compression_internal.h +1 -1
  515. data/src/core/lib/config/core_configuration.cc +3 -0
  516. data/src/core/lib/config/core_configuration.h +2 -1
  517. data/src/core/lib/debug/stats_data.cc +2 -6
  518. data/src/core/lib/debug/stats_data.h +18 -21
  519. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +4 -2
  520. data/src/core/lib/event_engine/channel_args_endpoint_config.h +3 -2
  521. data/src/core/lib/event_engine/default_event_engine_factory.cc +8 -2
  522. data/src/core/lib/event_engine/event_engine.cc +12 -2
  523. data/src/core/lib/event_engine/event_engine_factory.h +5 -0
  524. data/src/core/lib/event_engine/handle_containers.h +67 -0
  525. data/src/core/lib/event_engine/iomgr_engine.cc +206 -0
  526. data/src/core/lib/event_engine/iomgr_engine.h +118 -0
  527. data/src/core/lib/event_engine/memory_allocator.cc +12 -4
  528. data/src/core/lib/event_engine/resolved_address.cc +4 -2
  529. data/src/core/lib/event_engine/slice.cc +102 -0
  530. data/src/core/lib/event_engine/slice_buffer.cc +50 -0
  531. data/src/core/{ext/filters/max_age/max_age_filter.h → lib/event_engine/trace.cc} +3 -11
  532. data/src/core/lib/{iomgr/endpoint_pair_event_engine.cc → event_engine/trace.h} +12 -14
  533. data/src/core/lib/gpr/log.cc +5 -0
  534. data/src/core/lib/gpr/tls.h +4 -5
  535. data/src/core/lib/gprpp/bitset.h +17 -1
  536. data/src/core/lib/gprpp/chunked_vector.h +4 -0
  537. data/src/core/lib/gprpp/construct_destruct.h +1 -0
  538. data/src/core/lib/gprpp/cpp_impl_of.h +4 -0
  539. data/src/core/lib/gprpp/dual_ref_counted.h +1 -4
  540. data/src/core/lib/gprpp/examine_stack.h +0 -1
  541. data/src/core/lib/gprpp/fork.cc +3 -6
  542. data/src/core/lib/gprpp/global_config.h +2 -4
  543. data/src/core/lib/gprpp/global_config_env.cc +3 -2
  544. data/src/core/lib/gprpp/global_config_env.h +3 -1
  545. data/src/core/lib/gprpp/global_config_generic.h +0 -4
  546. data/src/core/lib/gprpp/host_port.cc +2 -0
  547. data/src/core/lib/gprpp/manual_constructor.h +0 -1
  548. data/src/core/lib/gprpp/match.h +75 -0
  549. data/src/core/lib/gprpp/memory.h +1 -5
  550. data/src/core/lib/gprpp/orphanable.h +1 -4
  551. data/src/core/lib/gprpp/overload.h +59 -0
  552. data/src/core/lib/gprpp/ref_counted.h +3 -3
  553. data/src/core/lib/gprpp/ref_counted_ptr.h +1 -1
  554. data/src/core/lib/gprpp/single_set_ptr.h +87 -0
  555. data/src/core/lib/gprpp/stat.h +0 -2
  556. data/src/core/lib/gprpp/stat_posix.cc +7 -2
  557. data/src/core/lib/gprpp/status_helper.cc +25 -5
  558. data/src/core/lib/gprpp/status_helper.h +4 -0
  559. data/src/core/lib/gprpp/sync.h +3 -1
  560. data/src/core/lib/gprpp/table.h +10 -0
  561. data/src/core/lib/gprpp/thd.h +2 -5
  562. data/src/core/lib/gprpp/thd_posix.cc +4 -2
  563. data/src/core/lib/gprpp/thd_windows.cc +2 -0
  564. data/src/core/lib/gprpp/time.cc +20 -0
  565. data/src/core/lib/gprpp/time.h +7 -2
  566. data/src/core/lib/gprpp/time_util.cc +4 -0
  567. data/src/core/lib/gprpp/time_util.h +1 -1
  568. data/src/core/lib/gprpp/unique_type_name.h +104 -0
  569. data/src/core/lib/http/format_request.cc +30 -2
  570. data/src/core/lib/http/format_request.h +2 -0
  571. data/src/core/lib/http/httpcli.cc +88 -81
  572. data/src/core/lib/http/httpcli.h +39 -7
  573. data/src/core/lib/http/httpcli_security_connector.cc +6 -7
  574. data/src/core/lib/http/parser.cc +80 -9
  575. data/src/core/lib/http/parser.h +14 -1
  576. data/src/core/lib/iomgr/endpoint.cc +4 -4
  577. data/src/core/lib/iomgr/endpoint.h +6 -4
  578. data/src/core/lib/iomgr/endpoint_cfstream.cc +7 -4
  579. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -1
  580. data/src/core/lib/iomgr/ev_posix.cc +7 -11
  581. data/src/core/lib/iomgr/exec_ctx.h +1 -2
  582. data/src/core/lib/iomgr/fork_posix.cc +1 -1
  583. data/src/core/lib/iomgr/internal_errqueue.cc +38 -47
  584. data/src/core/lib/iomgr/internal_errqueue.h +1 -6
  585. data/src/core/lib/iomgr/iomgr.cc +0 -1
  586. data/src/core/lib/iomgr/{event_engine/pollset.h → iomgr_fwd.h} +9 -9
  587. data/src/core/lib/iomgr/pollset_set.h +1 -2
  588. data/src/core/lib/iomgr/port.h +25 -8
  589. data/src/core/lib/iomgr/resolve_address.cc +8 -0
  590. data/src/core/lib/iomgr/resolve_address.h +21 -14
  591. data/src/core/lib/iomgr/resolve_address_impl.h +2 -3
  592. data/src/core/lib/iomgr/resolve_address_posix.cc +8 -14
  593. data/src/core/lib/iomgr/resolve_address_posix.h +5 -2
  594. data/src/core/lib/iomgr/resolve_address_windows.cc +7 -14
  595. data/src/core/lib/iomgr/resolve_address_windows.h +5 -2
  596. data/src/core/lib/iomgr/sockaddr.h +2 -3
  597. data/src/core/lib/iomgr/sockaddr_posix.h +2 -0
  598. data/src/core/lib/iomgr/sockaddr_windows.h +2 -0
  599. data/src/core/lib/iomgr/socket_utils_common_posix.cc +3 -2
  600. data/src/core/lib/iomgr/tcp_client_cfstream.cc +10 -2
  601. data/src/core/lib/iomgr/tcp_client_posix.cc +14 -7
  602. data/src/core/lib/iomgr/tcp_client_windows.cc +13 -6
  603. data/src/core/lib/iomgr/tcp_posix.cc +77 -37
  604. data/src/core/lib/iomgr/tcp_server_posix.cc +50 -27
  605. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +30 -27
  606. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +7 -4
  607. data/src/core/lib/iomgr/tcp_server_windows.cc +13 -5
  608. data/src/core/lib/iomgr/tcp_windows.cc +7 -4
  609. data/src/core/lib/json/json.h +1 -2
  610. data/src/core/lib/json/json_reader.cc +9 -1
  611. data/src/core/lib/json/json_util.cc +7 -0
  612. data/src/core/lib/json/json_util.h +13 -4
  613. data/src/core/lib/json/json_writer.cc +6 -1
  614. data/src/core/lib/promise/activity.cc +1 -1
  615. data/src/core/lib/promise/activity.h +6 -6
  616. data/src/core/lib/promise/arena_promise.h +11 -1
  617. data/src/core/lib/promise/call_push_pull.h +148 -0
  618. data/src/core/lib/promise/context.h +1 -1
  619. data/src/core/lib/promise/detail/basic_seq.h +2 -2
  620. data/src/core/lib/promise/detail/promise_factory.h +0 -1
  621. data/src/core/lib/promise/detail/status.h +2 -1
  622. data/src/core/lib/promise/intra_activity_waiter.h +49 -0
  623. data/src/core/lib/promise/latch.h +103 -0
  624. data/src/core/lib/promise/loop.h +1 -0
  625. data/src/core/lib/promise/race.h +0 -1
  626. data/src/core/lib/promise/seq.h +0 -2
  627. data/src/core/lib/promise/sleep.cc +2 -0
  628. data/src/core/lib/promise/sleep.h +10 -0
  629. data/src/core/lib/promise/try_seq.h +2 -2
  630. data/src/core/lib/resolver/resolver_factory.h +1 -2
  631. data/src/core/lib/resolver/server_address.cc +9 -3
  632. data/src/core/lib/resolver/server_address.h +4 -4
  633. data/src/core/lib/resource_quota/api.cc +19 -31
  634. data/src/core/lib/resource_quota/api.h +5 -2
  635. data/src/core/lib/resource_quota/arena.cc +0 -6
  636. data/src/core/lib/resource_quota/arena.h +1 -2
  637. data/src/core/lib/resource_quota/memory_quota.cc +47 -5
  638. data/src/core/lib/resource_quota/memory_quota.h +24 -5
  639. data/src/core/lib/resource_quota/resource_quota.h +16 -0
  640. data/src/core/lib/resource_quota/thread_quota.cc +2 -0
  641. data/src/core/lib/resource_quota/thread_quota.h +4 -0
  642. data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
  643. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +12 -12
  644. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +5 -6
  645. data/src/core/lib/security/context/security_context.h +8 -1
  646. data/src/core/lib/security/credentials/alts/alts_credentials.cc +12 -5
  647. data/src/core/lib/security/credentials/alts/alts_credentials.h +4 -0
  648. data/src/core/lib/security/credentials/call_creds_util.cc +5 -3
  649. data/src/core/lib/security/credentials/call_creds_util.h +2 -2
  650. data/src/core/lib/security/credentials/channel_creds_registry.h +1 -0
  651. data/src/core/lib/security/credentials/composite/composite_credentials.cc +19 -10
  652. data/src/core/lib/security/credentials/composite/composite_credentials.h +11 -9
  653. data/src/core/lib/security/credentials/credentials.h +29 -39
  654. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +81 -0
  655. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +8 -0
  656. data/src/core/lib/security/credentials/external/external_account_credentials.cc +3 -0
  657. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +2 -0
  658. data/src/core/lib/security/credentials/fake/fake_credentials.cc +18 -12
  659. data/src/core/lib/security/credentials/fake/fake_credentials.h +8 -5
  660. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +27 -13
  661. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +4 -4
  662. data/src/core/lib/security/credentials/iam/iam_credentials.cc +8 -4
  663. data/src/core/lib/security/credentials/iam/iam_credentials.h +6 -2
  664. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +28 -29
  665. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +57 -0
  666. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +8 -3
  667. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +6 -2
  668. data/src/core/lib/security/credentials/local/local_credentials.cc +12 -6
  669. data/src/core/lib/security/credentials/local/local_credentials.h +4 -0
  670. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +22 -10
  671. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +14 -6
  672. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +11 -6
  673. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +8 -6
  674. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +12 -4
  675. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +8 -0
  676. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +10 -0
  677. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +47 -0
  678. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +34 -1
  679. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +66 -3
  680. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +66 -95
  681. data/src/core/lib/security/credentials/tls/tls_credentials.cc +19 -6
  682. data/src/core/lib/security/credentials/tls/tls_credentials.h +5 -5
  683. data/src/core/lib/security/credentials/xds/xds_credentials.cc +57 -50
  684. data/src/core/lib/security/credentials/xds/xds_credentials.h +31 -5
  685. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -1
  686. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +1 -1
  687. data/src/core/lib/security/security_connector/local/local_security_connector.cc +2 -2
  688. data/src/core/lib/security/security_connector/security_connector.cc +1 -1
  689. data/src/core/lib/security/security_connector/security_connector.h +10 -1
  690. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +5 -3
  691. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +4 -2
  692. data/src/core/lib/security/transport/auth_filters.h +7 -7
  693. data/src/core/lib/security/transport/client_auth_filter.cc +26 -20
  694. data/src/core/lib/security/transport/secure_endpoint.cc +213 -133
  695. data/src/core/lib/security/transport/secure_endpoint.h +1 -1
  696. data/src/core/lib/security/transport/security_handshaker.cc +11 -9
  697. data/src/core/lib/security/transport/security_handshaker.h +1 -1
  698. data/src/core/lib/security/transport/server_auth_filter.cc +3 -2
  699. data/src/core/lib/service_config/service_config.h +4 -8
  700. data/src/core/lib/service_config/service_config_call_data.h +4 -1
  701. data/src/core/lib/service_config/service_config_impl.cc +7 -0
  702. data/src/core/lib/service_config/service_config_impl.h +9 -2
  703. data/src/core/lib/service_config/service_config_parser.cc +8 -0
  704. data/src/core/lib/service_config/service_config_parser.h +7 -0
  705. data/src/core/lib/slice/b64.cc +1 -1
  706. data/src/core/lib/slice/b64.h +2 -0
  707. data/src/core/lib/slice/percent_encoding.cc +4 -1
  708. data/src/core/lib/slice/percent_encoding.h +0 -6
  709. data/src/core/lib/slice/slice.cc +2 -1
  710. data/src/core/lib/slice/slice.h +10 -5
  711. data/src/core/lib/slice/slice_api.cc +1 -1
  712. data/src/core/lib/slice/slice_buffer.cc +50 -23
  713. data/src/core/lib/slice/slice_buffer.h +106 -0
  714. data/src/core/lib/{iomgr/is_epollexclusive_available.h → slice/slice_buffer_api.cc} +11 -12
  715. data/src/core/lib/slice/slice_internal.h +4 -3
  716. data/src/core/lib/slice/slice_refcount.h +2 -3
  717. data/src/core/lib/slice/slice_refcount_base.h +2 -3
  718. data/src/core/lib/slice/slice_split.cc +3 -0
  719. data/src/core/lib/slice/slice_split.h +0 -4
  720. data/src/core/lib/slice/slice_string_helpers.cc +4 -0
  721. data/src/core/lib/slice/slice_string_helpers.h +1 -4
  722. data/src/core/lib/surface/builtins.cc +7 -2
  723. data/src/core/lib/surface/byte_buffer.cc +7 -1
  724. data/src/core/lib/surface/byte_buffer_reader.cc +4 -4
  725. data/src/core/lib/surface/call.cc +1052 -917
  726. data/src/core/lib/surface/call.h +16 -16
  727. data/src/core/lib/surface/call_details.cc +4 -4
  728. data/src/core/lib/surface/call_log_batch.cc +7 -1
  729. data/src/core/lib/surface/call_test_only.h +4 -1
  730. data/src/core/lib/surface/channel.cc +181 -243
  731. data/src/core/lib/surface/channel.h +94 -57
  732. data/src/core/lib/surface/channel_init.cc +2 -3
  733. data/src/core/lib/surface/channel_init.h +3 -5
  734. data/src/core/lib/surface/channel_ping.cc +8 -2
  735. data/src/core/lib/surface/channel_stack_type.cc +0 -2
  736. data/src/core/lib/surface/channel_stack_type.h +0 -2
  737. data/src/core/lib/surface/completion_queue.cc +14 -6
  738. data/src/core/lib/surface/completion_queue.h +5 -1
  739. data/src/core/lib/surface/completion_queue_factory.cc +1 -0
  740. data/src/core/lib/surface/completion_queue_factory.h +1 -3
  741. data/src/core/lib/surface/event_string.cc +1 -7
  742. data/src/core/lib/surface/event_string.h +1 -1
  743. data/src/core/lib/surface/init.cc +17 -45
  744. data/src/core/lib/surface/init.h +0 -8
  745. data/src/core/lib/surface/lame_client.cc +64 -110
  746. data/src/core/lib/surface/lame_client.h +40 -2
  747. data/src/core/lib/surface/metadata_array.cc +2 -0
  748. data/src/core/lib/surface/server.cc +72 -70
  749. data/src/core/lib/surface/server.h +40 -11
  750. data/src/core/lib/surface/validate_metadata.cc +2 -5
  751. data/src/core/lib/surface/validate_metadata.h +3 -0
  752. data/src/core/lib/surface/version.cc +2 -2
  753. data/src/core/lib/transport/bdp_estimator.cc +3 -1
  754. data/src/core/lib/transport/bdp_estimator.h +2 -3
  755. data/src/core/lib/transport/byte_stream.cc +6 -3
  756. data/src/core/lib/transport/byte_stream.h +5 -1
  757. data/src/core/lib/transport/connectivity_state.cc +6 -4
  758. data/src/core/lib/transport/connectivity_state.h +2 -3
  759. data/src/core/lib/transport/error_utils.cc +4 -2
  760. data/src/core/lib/transport/error_utils.h +5 -1
  761. data/src/core/lib/{channel → transport}/handshaker.cc +9 -4
  762. data/src/core/lib/{channel → transport}/handshaker.h +13 -6
  763. data/src/core/lib/{channel → transport}/handshaker_factory.h +9 -10
  764. data/src/core/lib/{channel → transport}/handshaker_registry.cc +5 -1
  765. data/src/core/lib/{channel → transport}/handshaker_registry.h +5 -4
  766. data/src/core/{ext/filters/client_channel → lib/transport}/http_connect_handshaker.cc +24 -10
  767. data/src/core/{ext/filters/client_channel → lib/transport}/http_connect_handshaker.h +3 -3
  768. data/src/core/lib/transport/metadata_batch.cc +287 -0
  769. data/src/core/lib/transport/metadata_batch.h +142 -269
  770. data/src/core/lib/transport/parsed_metadata.cc +2 -0
  771. data/src/core/lib/transport/parsed_metadata.h +10 -3
  772. data/src/core/lib/transport/status_conversion.cc +2 -0
  773. data/src/core/lib/transport/status_conversion.h +2 -2
  774. data/src/core/lib/transport/tcp_connect_handshaker.cc +253 -0
  775. data/src/core/lib/transport/tcp_connect_handshaker.h +39 -0
  776. data/src/core/lib/transport/timeout_encoding.cc +2 -6
  777. data/src/core/lib/transport/timeout_encoding.h +5 -1
  778. data/src/core/lib/transport/transport.cc +18 -17
  779. data/src/core/lib/transport/transport.h +48 -7
  780. data/src/core/lib/transport/transport_impl.h +14 -3
  781. data/src/core/lib/transport/transport_op_string.cc +9 -10
  782. data/src/core/lib/uri/uri_parser.cc +11 -3
  783. data/src/core/lib/uri/uri_parser.h +0 -2
  784. data/src/core/plugin_registry/grpc_plugin_registry.cc +13 -4
  785. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +2 -2
  786. data/src/core/tsi/ssl/session_cache/ssl_session.h +2 -0
  787. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +2 -0
  788. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -0
  789. data/src/core/tsi/ssl_transport_security.cc +75 -38
  790. data/src/core/tsi/ssl_transport_security.h +8 -2
  791. data/src/core/tsi/transport_security_interface.h +2 -0
  792. data/src/ruby/ext/grpc/extconf.rb +2 -2
  793. data/src/ruby/lib/grpc/generic/active_call.rb +7 -1
  794. data/src/ruby/lib/grpc/grpc.rb +1 -1
  795. data/src/ruby/lib/grpc/version.rb +1 -1
  796. data/src/ruby/pb/generate_proto_ruby.sh +1 -0
  797. data/src/ruby/pb/test/client.rb +769 -0
  798. data/src/ruby/pb/test/server.rb +252 -0
  799. data/src/ruby/pb/test/xds_client.rb +415 -0
  800. data/third_party/abseil-cpp/absl/cleanup/cleanup.h +140 -0
  801. data/third_party/abseil-cpp/absl/cleanup/internal/cleanup.h +100 -0
  802. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +504 -0
  803. data/third_party/upb/third_party/utf8_range/utf8_range.h +1 -1
  804. data/third_party/upb/upb/decode.c +32 -16
  805. data/third_party/upb/upb/def.c +118 -55
  806. data/third_party/upb/upb/def.h +12 -3
  807. data/third_party/upb/upb/encode.c +14 -8
  808. data/third_party/upb/upb/json_encode.c +776 -0
  809. data/third_party/upb/upb/json_encode.h +62 -0
  810. data/third_party/upb/upb/msg.c +5 -7
  811. data/third_party/upb/upb/msg.h +1 -2
  812. data/third_party/upb/upb/msg_internal.h +49 -36
  813. data/third_party/upb/upb/port_def.inc +8 -0
  814. data/third_party/upb/upb/port_undef.inc +1 -0
  815. data/third_party/upb/upb/table.c +10 -6
  816. data/third_party/upb/upb/table_internal.h +2 -0
  817. data/third_party/upb/upb/upb.h +41 -11
  818. data/third_party/zlib/crc32.c +966 -292
  819. data/third_party/zlib/crc32.h +9441 -436
  820. data/third_party/zlib/deflate.c +78 -30
  821. data/third_party/zlib/deflate.h +12 -15
  822. data/third_party/zlib/gzguts.h +3 -2
  823. data/third_party/zlib/gzlib.c +5 -3
  824. data/third_party/zlib/gzread.c +5 -7
  825. data/third_party/zlib/gzwrite.c +25 -13
  826. data/third_party/zlib/infback.c +2 -1
  827. data/third_party/zlib/inffast.c +14 -14
  828. data/third_party/zlib/inflate.c +39 -8
  829. data/third_party/zlib/inflate.h +3 -2
  830. data/third_party/zlib/inftrees.c +3 -3
  831. data/third_party/zlib/trees.c +27 -48
  832. data/third_party/zlib/zlib.h +123 -100
  833. data/third_party/zlib/zutil.c +2 -2
  834. data/third_party/zlib/zutil.h +12 -9
  835. metadata +100 -72
  836. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_event_engine.cc +0 -31
  837. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_event_engine.cc +0 -28
  838. data/src/core/ext/filters/client_idle/client_idle_filter.cc +0 -201
  839. data/src/core/ext/filters/max_age/max_age_filter.cc +0 -566
  840. data/src/core/lib/event_engine/sockaddr.cc +0 -40
  841. data/src/core/lib/event_engine/sockaddr.h +0 -44
  842. data/src/core/lib/gprpp/capture.h +0 -76
  843. data/src/core/lib/iomgr/ev_epollex_linux.cc +0 -1657
  844. data/src/core/lib/iomgr/ev_epollex_linux.h +0 -30
  845. data/src/core/lib/iomgr/event_engine/closure.cc +0 -77
  846. data/src/core/lib/iomgr/event_engine/closure.h +0 -42
  847. data/src/core/lib/iomgr/event_engine/endpoint.cc +0 -172
  848. data/src/core/lib/iomgr/event_engine/endpoint.h +0 -52
  849. data/src/core/lib/iomgr/event_engine/iomgr.cc +0 -85
  850. data/src/core/lib/iomgr/event_engine/pollset.cc +0 -87
  851. data/src/core/lib/iomgr/event_engine/promise.h +0 -51
  852. data/src/core/lib/iomgr/event_engine/resolved_address_internal.cc +0 -47
  853. data/src/core/lib/iomgr/event_engine/resolved_address_internal.h +0 -37
  854. data/src/core/lib/iomgr/event_engine/resolver.cc +0 -133
  855. data/src/core/lib/iomgr/event_engine/resolver.h +0 -56
  856. data/src/core/lib/iomgr/event_engine/tcp.cc +0 -296
  857. data/src/core/lib/iomgr/event_engine/timer.cc +0 -62
  858. data/src/core/lib/iomgr/is_epollexclusive_available.cc +0 -119
  859. data/src/core/lib/iomgr/sys_epoll_wrapper.h +0 -30
@@ -17,38 +17,60 @@
17
17
  #include <grpc/support/port_platform.h>
18
18
 
19
19
  #include <inttypes.h>
20
- #include <limits.h>
21
-
20
+ #include <stddef.h>
21
+
22
+ #include <algorithm>
23
+ #include <map>
24
+ #include <memory>
25
+ #include <set>
26
+ #include <string>
27
+ #include <utility>
28
+ #include <vector>
29
+
30
+ #include "absl/container/inlined_vector.h"
31
+ #include "absl/memory/memory.h"
32
+ #include "absl/status/status.h"
33
+ #include "absl/status/statusor.h"
22
34
  #include "absl/strings/str_cat.h"
35
+ #include "absl/strings/string_view.h"
23
36
  #include "absl/types/optional.h"
24
37
 
25
- #include <grpc/grpc.h>
38
+ #include <grpc/impl/codegen/connectivity_state.h>
39
+ #include <grpc/impl/codegen/grpc_types.h>
40
+ #include <grpc/support/log.h>
26
41
 
27
- #include "src/core/ext/filters/client_channel/client_channel.h"
28
42
  #include "src/core/ext/filters/client_channel/lb_policy.h"
29
43
  #include "src/core/ext/filters/client_channel/lb_policy/address_filtering.h"
30
44
  #include "src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h"
45
+ #include "src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h"
31
46
  #include "src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h"
32
47
  #include "src/core/ext/filters/client_channel/lb_policy/xds/xds.h"
33
48
  #include "src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h"
34
49
  #include "src/core/ext/filters/client_channel/lb_policy_factory.h"
35
50
  #include "src/core/ext/filters/client_channel/lb_policy_registry.h"
36
51
  #include "src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h"
52
+ #include "src/core/ext/filters/client_channel/subchannel_interface.h"
37
53
  #include "src/core/ext/xds/xds_bootstrap.h"
38
- #include "src/core/ext/xds/xds_channel_args.h"
39
54
  #include "src/core/ext/xds/xds_client.h"
40
55
  #include "src/core/ext/xds/xds_client_stats.h"
41
56
  #include "src/core/ext/xds/xds_endpoint.h"
57
+ #include "src/core/ext/xds/xds_resource_type_impl.h"
42
58
  #include "src/core/lib/channel/channel_args.h"
43
59
  #include "src/core/lib/config/core_configuration.h"
60
+ #include "src/core/lib/debug/trace.h"
44
61
  #include "src/core/lib/gpr/string.h"
62
+ #include "src/core/lib/gprpp/debug_location.h"
45
63
  #include "src/core/lib/gprpp/orphanable.h"
46
64
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
65
+ #include "src/core/lib/gprpp/time.h"
66
+ #include "src/core/lib/iomgr/error.h"
67
+ #include "src/core/lib/iomgr/pollset_set.h"
47
68
  #include "src/core/lib/iomgr/work_serializer.h"
69
+ #include "src/core/lib/json/json.h"
70
+ #include "src/core/lib/resolver/resolver.h"
48
71
  #include "src/core/lib/resolver/resolver_registry.h"
49
72
  #include "src/core/lib/resolver/server_address.h"
50
- #include "src/core/lib/transport/error_utils.h"
51
- #include "src/core/lib/uri/uri_parser.h"
73
+ #include "src/core/lib/transport/connectivity_state.h"
52
74
 
53
75
  #define GRPC_EDS_DEFAULT_FALLBACK_TIMEOUT 10000
54
76
 
@@ -76,6 +98,7 @@ class XdsClusterResolverLbConfig : public LoadBalancingPolicy::Config {
76
98
  DiscoveryMechanismType type;
77
99
  std::string eds_service_name;
78
100
  std::string dns_hostname;
101
+ absl::optional<Json::Object> outlier_detection_lb_config;
79
102
 
80
103
  bool operator==(const DiscoveryMechanism& other) const {
81
104
  return (cluster_name == other.cluster_name &&
@@ -83,7 +106,8 @@ class XdsClusterResolverLbConfig : public LoadBalancingPolicy::Config {
83
106
  max_concurrent_requests == other.max_concurrent_requests &&
84
107
  type == other.type &&
85
108
  eds_service_name == other.eds_service_name &&
86
- dns_hostname == other.dns_hostname);
109
+ dns_hostname == other.dns_hostname &&
110
+ outlier_detection_lb_config == other.outlier_detection_lb_config);
87
111
  }
88
112
  };
89
113
 
@@ -131,24 +155,14 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
131
155
  RefCountedPtr<XdsClusterResolverLb> xds_cluster_resolver_lb,
132
156
  size_t index)
133
157
  : parent_(std::move(xds_cluster_resolver_lb)), index_(index) {}
134
- virtual void Start() = 0;
135
- void Orphan() override = 0;
136
- virtual Json::Array override_child_policy() = 0;
137
- virtual bool disable_reresolution() = 0;
138
158
 
139
- // Returns a pair containing the cluster and eds_service_name
140
- // to use for LRS load reporting. Caller must ensure that config_ is set
141
- // before calling.
142
- std::pair<absl::string_view, absl::string_view> GetLrsClusterKey() const {
143
- return {
144
- parent_->config_->discovery_mechanisms()[index_].cluster_name,
145
- parent_->config_->discovery_mechanisms()[index_].eds_service_name};
146
- }
147
-
148
- protected:
149
159
  XdsClusterResolverLb* parent() const { return parent_.get(); }
150
160
  size_t index() const { return index_; }
151
161
 
162
+ virtual void Start() = 0;
163
+ virtual Json::Array override_child_policy() = 0;
164
+ virtual bool disable_reresolution() = 0;
165
+
152
166
  private:
153
167
  RefCountedPtr<XdsClusterResolverLb> parent_;
154
168
  // Stores its own index in the vector of DiscoveryMechanism.
@@ -186,11 +200,11 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
186
200
  },
187
201
  DEBUG_LOCATION);
188
202
  }
189
- void OnError(grpc_error_handle error) override {
203
+ void OnError(absl::Status status) override {
190
204
  Ref().release(); // ref held by callback
191
205
  discovery_mechanism_->parent()->work_serializer()->Run(
192
- [this, error]() {
193
- OnErrorHelper(error);
206
+ [this, status]() {
207
+ OnErrorHelper(status);
194
208
  Unref();
195
209
  },
196
210
  DEBUG_LOCATION);
@@ -213,9 +227,9 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
213
227
  discovery_mechanism_->parent()->OnEndpointChanged(
214
228
  discovery_mechanism_->index(), std::move(update));
215
229
  }
216
- void OnErrorHelper(grpc_error_handle error) {
230
+ void OnErrorHelper(absl::Status status) {
217
231
  discovery_mechanism_->parent()->OnError(discovery_mechanism_->index(),
218
- error);
232
+ status);
219
233
  }
220
234
  void OnResourceDoesNotExistHelper() {
221
235
  discovery_mechanism_->parent()->OnResourceDoesNotExist(
@@ -229,14 +243,9 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
229
243
  friend class EndpointWatcher;
230
244
 
231
245
  absl::string_view GetEdsResourceName() const {
232
- if (!parent()
233
- ->config_->discovery_mechanisms()[index()]
234
- .eds_service_name.empty()) {
235
- return parent()
236
- ->config_->discovery_mechanisms()[index()]
237
- .eds_service_name;
238
- }
239
- return parent()->config_->discovery_mechanisms()[index()].cluster_name;
246
+ auto& config = parent()->config_->discovery_mechanisms()[index()];
247
+ if (!config.eds_service_name.empty()) return config.eds_service_name;
248
+ return config.cluster_name;
240
249
  }
241
250
 
242
251
  // Note that this is not owned, so this pointer must never be dereferenced.
@@ -284,15 +293,16 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
284
293
 
285
294
  struct DiscoveryMechanismEntry {
286
295
  OrphanablePtr<DiscoveryMechanism> discovery_mechanism;
287
- bool first_update_received = false;
288
- // Number of priorities this mechanism has contributed to priority_list_.
289
- // (The sum of this across all discovery mechanisms should always equal
290
- // the number of priorities in priority_list_.)
291
- uint32_t num_priorities = 0;
292
- RefCountedPtr<XdsEndpointResource::DropConfig> drop_config;
293
- // Populated only when an update has been delivered by the mechanism
294
- // but has not yet been applied to the LB policy's combined priority_list_.
295
- absl::optional<XdsEndpointResource::PriorityList> pending_priority_list;
296
+ // Most recent update reported by the discovery mechanism.
297
+ absl::optional<XdsEndpointResource> latest_update;
298
+ // State used to retain child policy names for priority policy.
299
+ std::vector<size_t /*child_number*/> priority_child_numbers;
300
+ size_t next_available_child_number = 0;
301
+
302
+ const XdsClusterResolverLbConfig::DiscoveryMechanism& config() const;
303
+
304
+ // Returns the child policy name for a given priority.
305
+ std::string GetChildPolicyName(size_t priority) const;
296
306
  };
297
307
 
298
308
  class Helper : public ChannelControlHelper {
@@ -326,12 +336,11 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
326
336
  void ShutdownLocked() override;
327
337
 
328
338
  void OnEndpointChanged(size_t index, XdsEndpointResource update);
329
- void OnError(size_t index, grpc_error_handle error);
339
+ void OnError(size_t index, absl::Status status);
330
340
  void OnResourceDoesNotExist(size_t index);
331
341
 
332
342
  void MaybeDestroyChildPolicyLocked();
333
343
 
334
- void UpdatePriorityList(XdsEndpointResource::PriorityList priority_list);
335
344
  void UpdateChildPolicyLocked();
336
345
  OrphanablePtr<LoadBalancingPolicy> CreateChildPolicyLocked(
337
346
  const grpc_channel_args* args);
@@ -353,11 +362,6 @@ class XdsClusterResolverLb : public LoadBalancingPolicy {
353
362
  // Vector of discovery mechansism entries in priority order.
354
363
  std::vector<DiscoveryMechanismEntry> discovery_mechanisms_;
355
364
 
356
- // The latest data from the endpoint watcher.
357
- XdsEndpointResource::PriorityList priority_list_;
358
- // State used to retain child policy names for priority policy.
359
- std::vector<size_t /*child_number*/> priority_child_numbers_;
360
-
361
365
  OrphanablePtr<LoadBalancingPolicy> child_policy_;
362
366
  };
363
367
 
@@ -491,9 +495,8 @@ void XdsClusterResolverLb::LogicalDNSDiscoveryMechanism::Orphan() {
491
495
  void XdsClusterResolverLb::LogicalDNSDiscoveryMechanism::ResolverResultHandler::
492
496
  ReportResult(Resolver::Result result) {
493
497
  if (!result.addresses.ok()) {
494
- discovery_mechanism_->parent()->OnError(
495
- discovery_mechanism_->index(),
496
- absl_status_to_grpc_error(result.addresses.status()));
498
+ discovery_mechanism_->parent()->OnError(discovery_mechanism_->index(),
499
+ result.addresses.status());
497
500
  return;
498
501
  }
499
502
  // Convert resolver result to EDS update.
@@ -511,6 +514,22 @@ void XdsClusterResolverLb::LogicalDNSDiscoveryMechanism::ResolverResultHandler::
511
514
  discovery_mechanism_->index(), std::move(update));
512
515
  }
513
516
 
517
+ //
518
+ // XdsClusterResolverLb::DiscoveryMechanismEntry
519
+ //
520
+
521
+ const XdsClusterResolverLbConfig::DiscoveryMechanism&
522
+ XdsClusterResolverLb::DiscoveryMechanismEntry::config() const {
523
+ return discovery_mechanism->parent()
524
+ ->config_->discovery_mechanisms()[discovery_mechanism->index()];
525
+ }
526
+
527
+ std::string XdsClusterResolverLb::DiscoveryMechanismEntry::GetChildPolicyName(
528
+ size_t priority) const {
529
+ return absl::StrCat("{cluster=", config().cluster_name,
530
+ ", child_number=", priority_child_numbers[priority], "}");
531
+ }
532
+
514
533
  //
515
534
  // XdsClusterResolverLb public methods
516
535
  //
@@ -614,100 +633,37 @@ void XdsClusterResolverLb::OnEndpointChanged(size_t index,
614
633
  " for discovery mechanism %" PRIuPTR "",
615
634
  this, index);
616
635
  }
636
+ DiscoveryMechanismEntry& discovery_entry = discovery_mechanisms_[index];
617
637
  // We need at least one priority for each discovery mechanism, just so that we
618
638
  // have a child in which to create the xds_cluster_impl policy. This ensures
619
639
  // that we properly handle the case of a discovery mechanism dropping 100% of
620
640
  // calls, the OnError() case, and the OnResourceDoesNotExist() case.
621
641
  if (update.priorities.empty()) update.priorities.emplace_back();
622
- discovery_mechanisms_[index].drop_config = std::move(update.drop_config);
623
- discovery_mechanisms_[index].pending_priority_list =
624
- std::move(update.priorities);
625
- discovery_mechanisms_[index].first_update_received = true;
626
- // If any discovery mechanism has not received its first update,
627
- // wait until that happens before creating the child policy.
628
- // TODO(roth): If this becomes problematic in the future (e.g., a
629
- // secondary discovery mechanism delaying us from starting up at all),
630
- // we can consider some sort of optimization whereby we can create the
631
- // priority policy with only a subset of its children. But we need to
632
- // make sure not to get into a situation where the priority policy
633
- // will put the channel into TRANSIENT_FAILURE instead of CONNECTING
634
- // while we're still waiting for the other discovery mechanism(s).
635
- for (DiscoveryMechanismEntry& mechanism : discovery_mechanisms_) {
636
- if (!mechanism.first_update_received) return;
637
- }
638
- // Construct new priority list.
639
- XdsEndpointResource::PriorityList priority_list;
640
- size_t priority_index = 0;
641
- for (DiscoveryMechanismEntry& mechanism : discovery_mechanisms_) {
642
- // If the mechanism has a pending update, use that.
643
- // Otherwise, use the priorities that it previously contributed to the
644
- // combined list.
645
- if (mechanism.pending_priority_list.has_value()) {
646
- priority_list.insert(priority_list.end(),
647
- mechanism.pending_priority_list->begin(),
648
- mechanism.pending_priority_list->end());
649
- priority_index += mechanism.num_priorities;
650
- mechanism.num_priorities = mechanism.pending_priority_list->size();
651
- mechanism.pending_priority_list.reset();
652
- } else {
653
- priority_list.insert(
654
- priority_list.end(), priority_list_.begin() + priority_index,
655
- priority_list_.begin() + priority_index + mechanism.num_priorities);
656
- priority_index += mechanism.num_priorities;
657
- }
658
- }
659
- // Update child policy.
660
- UpdatePriorityList(std::move(priority_list));
661
- }
662
-
663
- void XdsClusterResolverLb::OnError(size_t index, grpc_error_handle error) {
664
- gpr_log(GPR_ERROR,
665
- "[xds_cluster_resolver_lb %p] discovery mechanism %" PRIuPTR
666
- " xds watcher reported error: %s",
667
- this, index, grpc_error_std_string(error).c_str());
668
- GRPC_ERROR_UNREF(error);
669
- if (shutting_down_) return;
670
- if (!discovery_mechanisms_[index].first_update_received) {
671
- // Call OnEndpointChanged with an empty update just like
672
- // OnResourceDoesNotExist.
673
- OnEndpointChanged(index, XdsEndpointResource());
674
- }
675
- }
676
-
677
- void XdsClusterResolverLb::OnResourceDoesNotExist(size_t index) {
678
- gpr_log(GPR_ERROR,
679
- "[xds_cluster_resolver_lb %p] discovery mechanism %" PRIuPTR
680
- " resource does not exist",
681
- this, index);
682
- if (shutting_down_) return;
683
- // Call OnEndpointChanged with an empty update.
684
- OnEndpointChanged(index, XdsEndpointResource());
685
- }
686
-
687
- //
688
- // child policy-related methods
689
- //
690
-
691
- void XdsClusterResolverLb::UpdatePriorityList(
692
- XdsEndpointResource::PriorityList priority_list) {
693
- // Build some maps from locality to child number and the reverse from
694
- // the old data in priority_list_ and priority_child_numbers_.
642
+ // Update priority_child_numbers, reusing old child numbers in an
643
+ // intelligent way to avoid unnecessary churn.
644
+ // First, build some maps from locality to child number and the reverse
645
+ // from the old data in the entry's update and priority_child_numbers.
695
646
  std::map<XdsLocalityName*, size_t /*child_number*/, XdsLocalityName::Less>
696
647
  locality_child_map;
697
- std::map<size_t, std::set<XdsLocalityName*>> child_locality_map;
698
- for (size_t priority = 0; priority < priority_list_.size(); ++priority) {
699
- size_t child_number = priority_child_numbers_[priority];
700
- const auto& localities = priority_list_[priority].localities;
701
- for (const auto& p : localities) {
702
- XdsLocalityName* locality_name = p.first;
703
- locality_child_map[locality_name] = child_number;
704
- child_locality_map[child_number].insert(locality_name);
648
+ std::map<size_t, std::set<XdsLocalityName*, XdsLocalityName::Less>>
649
+ child_locality_map;
650
+ if (discovery_entry.latest_update.has_value()) {
651
+ const auto& prev_priority_list = discovery_entry.latest_update->priorities;
652
+ for (size_t priority = 0; priority < prev_priority_list.size();
653
+ ++priority) {
654
+ size_t child_number = discovery_entry.priority_child_numbers[priority];
655
+ const auto& localities = prev_priority_list[priority].localities;
656
+ for (const auto& p : localities) {
657
+ XdsLocalityName* locality_name = p.first;
658
+ locality_child_map[locality_name] = child_number;
659
+ child_locality_map[child_number].insert(locality_name);
660
+ }
705
661
  }
706
662
  }
707
663
  // Construct new list of children.
708
664
  std::vector<size_t> priority_child_numbers;
709
- for (size_t priority = 0; priority < priority_list.size(); ++priority) {
710
- const auto& localities = priority_list[priority].localities;
665
+ for (size_t priority = 0; priority < update.priorities.size(); ++priority) {
666
+ const auto& localities = update.priorities[priority].localities;
711
667
  absl::optional<size_t> child_number;
712
668
  // If one of the localities in this priority already existed, reuse its
713
669
  // child number.
@@ -735,10 +691,11 @@ void XdsClusterResolverLb::UpdatePriorityList(
735
691
  }
736
692
  // If we didn't find an existing child number, assign a new one.
737
693
  if (!child_number.has_value()) {
738
- for (child_number = 0;
694
+ for (child_number = discovery_entry.next_available_child_number;
739
695
  child_locality_map.find(*child_number) != child_locality_map.end();
740
696
  ++(*child_number)) {
741
697
  }
698
+ discovery_entry.next_available_child_number = *child_number + 1;
742
699
  // Add entry so we know that the child number is in use.
743
700
  // (Don't need to add the list of localities, since we won't use them.)
744
701
  child_locality_map[*child_number];
@@ -746,42 +703,87 @@ void XdsClusterResolverLb::UpdatePriorityList(
746
703
  priority_child_numbers.push_back(*child_number);
747
704
  }
748
705
  // Save update.
749
- priority_list_ = std::move(priority_list);
750
- priority_child_numbers_ = std::move(priority_child_numbers);
706
+ discovery_entry.latest_update = std::move(update);
707
+ discovery_entry.priority_child_numbers = std::move(priority_child_numbers);
708
+ // If any discovery mechanism has not received its first update,
709
+ // wait until that happens before creating the child policy.
710
+ // TODO(roth): If this becomes problematic in the future (e.g., a
711
+ // secondary discovery mechanism delaying us from starting up at all),
712
+ // we can consider some sort of optimization whereby we can create the
713
+ // priority policy with only a subset of its children. But we need to
714
+ // make sure not to get into a situation where the priority policy
715
+ // will put the channel into TRANSIENT_FAILURE instead of CONNECTING
716
+ // while we're still waiting for the other discovery mechanism(s).
717
+ for (DiscoveryMechanismEntry& mechanism : discovery_mechanisms_) {
718
+ if (!mechanism.latest_update.has_value()) return;
719
+ }
751
720
  // Update child policy.
752
721
  UpdateChildPolicyLocked();
753
722
  }
754
723
 
724
+ void XdsClusterResolverLb::OnError(size_t index, absl::Status status) {
725
+ gpr_log(GPR_ERROR,
726
+ "[xds_cluster_resolver_lb %p] discovery mechanism %" PRIuPTR
727
+ " xds watcher reported error: %s",
728
+ this, index, status.ToString().c_str());
729
+ if (shutting_down_) return;
730
+ if (!discovery_mechanisms_[index].latest_update.has_value()) {
731
+ // Call OnEndpointChanged with an empty update just like
732
+ // OnResourceDoesNotExist.
733
+ OnEndpointChanged(index, XdsEndpointResource());
734
+ }
735
+ }
736
+
737
+ void XdsClusterResolverLb::OnResourceDoesNotExist(size_t index) {
738
+ gpr_log(GPR_ERROR,
739
+ "[xds_cluster_resolver_lb %p] discovery mechanism %" PRIuPTR
740
+ " resource does not exist",
741
+ this, index);
742
+ if (shutting_down_) return;
743
+ // Call OnEndpointChanged with an empty update.
744
+ OnEndpointChanged(index, XdsEndpointResource());
745
+ }
746
+
747
+ //
748
+ // child policy-related methods
749
+ //
750
+
755
751
  ServerAddressList XdsClusterResolverLb::CreateChildPolicyAddressesLocked() {
756
752
  ServerAddressList addresses;
757
- for (size_t priority = 0; priority < priority_list_.size(); ++priority) {
758
- const auto& localities = priority_list_[priority].localities;
759
- std::string priority_child_name =
760
- absl::StrCat("child", priority_child_numbers_[priority]);
761
- for (const auto& p : localities) {
762
- const auto& locality_name = p.first;
763
- const auto& locality = p.second;
764
- std::vector<std::string> hierarchical_path = {
765
- priority_child_name, locality_name->AsHumanReadableString()};
766
- for (const auto& endpoint : locality.endpoints) {
767
- const ServerAddressWeightAttribute* weight_attribute = static_cast<
768
- const ServerAddressWeightAttribute*>(endpoint.GetAttribute(
769
- ServerAddressWeightAttribute::kServerAddressWeightAttributeKey));
770
- uint32_t weight = locality.lb_weight;
771
- if (weight_attribute != nullptr) {
772
- weight = locality.lb_weight * weight_attribute->weight();
753
+ for (const auto& discovery_entry : discovery_mechanisms_) {
754
+ for (size_t priority = 0;
755
+ priority < discovery_entry.latest_update->priorities.size();
756
+ ++priority) {
757
+ const auto& priority_entry =
758
+ discovery_entry.latest_update->priorities[priority];
759
+ std::string priority_child_name =
760
+ discovery_entry.GetChildPolicyName(priority);
761
+ for (const auto& p : priority_entry.localities) {
762
+ const auto& locality_name = p.first;
763
+ const auto& locality = p.second;
764
+ std::vector<std::string> hierarchical_path = {
765
+ priority_child_name, locality_name->AsHumanReadableString()};
766
+ for (const auto& endpoint : locality.endpoints) {
767
+ const ServerAddressWeightAttribute* weight_attribute = static_cast<
768
+ const ServerAddressWeightAttribute*>(endpoint.GetAttribute(
769
+ ServerAddressWeightAttribute::kServerAddressWeightAttributeKey));
770
+ uint32_t weight = locality.lb_weight;
771
+ if (weight_attribute != nullptr) {
772
+ weight = locality.lb_weight * weight_attribute->weight();
773
+ }
774
+ addresses.emplace_back(
775
+ endpoint
776
+ .WithAttribute(
777
+ kHierarchicalPathAttributeKey,
778
+ MakeHierarchicalPathAttribute(hierarchical_path))
779
+ .WithAttribute(kXdsLocalityNameAttributeKey,
780
+ absl::make_unique<XdsLocalityAttribute>(
781
+ locality_name->Ref()))
782
+ .WithAttribute(
783
+ ServerAddressWeightAttribute::
784
+ kServerAddressWeightAttributeKey,
785
+ absl::make_unique<ServerAddressWeightAttribute>(weight)));
773
786
  }
774
- addresses.emplace_back(
775
- endpoint
776
- .WithAttribute(kHierarchicalPathAttributeKey,
777
- MakeHierarchicalPathAttribute(hierarchical_path))
778
- .WithAttribute(kXdsLocalityNameAttributeKey,
779
- absl::make_unique<XdsLocalityAttribute>(
780
- locality_name->Ref()))
781
- .WithAttribute(
782
- ServerAddressWeightAttribute::
783
- kServerAddressWeightAttributeKey,
784
- absl::make_unique<ServerAddressWeightAttribute>(weight)));
785
787
  }
786
788
  }
787
789
  }
@@ -792,139 +794,128 @@ RefCountedPtr<LoadBalancingPolicy::Config>
792
794
  XdsClusterResolverLb::CreateChildPolicyConfigLocked() {
793
795
  Json::Object priority_children;
794
796
  Json::Array priority_priorities;
795
- // Setting up index to iterate through the discovery mechanisms and keeping
796
- // track the discovery_mechanism each priority belongs to.
797
- size_t discovery_index = 0;
798
- // Setting up num_priorities_remaining to track the priorities in each
799
- // discovery_mechanism.
800
- size_t num_priorities_remaining_in_discovery =
801
- discovery_mechanisms_[discovery_index].num_priorities;
802
- for (size_t priority = 0; priority < priority_list_.size(); ++priority) {
803
- Json child_policy;
804
- if (!discovery_mechanisms_[discovery_index]
805
- .discovery_mechanism->override_child_policy()
806
- .empty()) {
807
- child_policy = discovery_mechanisms_[discovery_index]
808
- .discovery_mechanism->override_child_policy();
809
- } else {
810
- const auto& xds_lb_policy = config_->xds_lb_policy().object_value();
811
- if (xds_lb_policy.find("ROUND_ROBIN") != xds_lb_policy.end()) {
812
- const auto& localities = priority_list_[priority].localities;
813
- Json::Object weighted_targets;
814
- for (const auto& p : localities) {
815
- XdsLocalityName* locality_name = p.first;
816
- const auto& locality = p.second;
817
- // Construct JSON object containing locality name.
818
- Json::Object locality_name_json;
819
- if (!locality_name->region().empty()) {
820
- locality_name_json["region"] = locality_name->region();
821
- }
822
- if (!locality_name->zone().empty()) {
823
- locality_name_json["zone"] = locality_name->zone();
824
- }
825
- if (!locality_name->sub_zone().empty()) {
826
- locality_name_json["sub_zone"] = locality_name->sub_zone();
797
+ for (const auto& discovery_entry : discovery_mechanisms_) {
798
+ const auto& discovery_config = discovery_entry.config();
799
+ for (size_t priority = 0;
800
+ priority < discovery_entry.latest_update->priorities.size();
801
+ ++priority) {
802
+ const auto& priority_entry =
803
+ discovery_entry.latest_update->priorities[priority];
804
+ Json child_policy;
805
+ if (!discovery_entry.discovery_mechanism->override_child_policy()
806
+ .empty()) {
807
+ child_policy =
808
+ discovery_entry.discovery_mechanism->override_child_policy();
809
+ } else {
810
+ const auto& xds_lb_policy = config_->xds_lb_policy().object_value();
811
+ if (xds_lb_policy.find("ROUND_ROBIN") != xds_lb_policy.end()) {
812
+ const auto& localities = priority_entry.localities;
813
+ Json::Object weighted_targets;
814
+ for (const auto& p : localities) {
815
+ XdsLocalityName* locality_name = p.first;
816
+ const auto& locality = p.second;
817
+ // Add weighted target entry.
818
+ weighted_targets[locality_name->AsHumanReadableString()] =
819
+ Json::Object{
820
+ {"weight", locality.lb_weight},
821
+ {"childPolicy",
822
+ Json::Array{
823
+ Json::Object{
824
+ {"round_robin", Json::Object()},
825
+ },
826
+ }},
827
+ };
827
828
  }
828
- // Add weighted target entry.
829
- weighted_targets[locality_name->AsHumanReadableString()] =
829
+ // Construct locality-picking policy.
830
+ // Start with field from our config and add the "targets" field.
831
+ child_policy = Json::Array{
830
832
  Json::Object{
831
- {"weight", locality.lb_weight},
832
- {"childPolicy",
833
- Json::Array{
834
- Json::Object{
835
- {"round_robin", Json::Object()},
836
- },
833
+ {"weighted_target_experimental",
834
+ Json::Object{
835
+ {"targets", Json::Object()},
837
836
  }},
838
- };
837
+ },
838
+ };
839
+ Json::Object& config =
840
+ *(*child_policy.mutable_array())[0].mutable_object();
841
+ auto it = config.begin();
842
+ GPR_ASSERT(it != config.end());
843
+ (*it->second.mutable_object())["targets"] =
844
+ std::move(weighted_targets);
845
+ } else {
846
+ auto it = xds_lb_policy.find("RING_HASH");
847
+ GPR_ASSERT(it != xds_lb_policy.end());
848
+ Json::Object ring_hash_experimental_policy =
849
+ it->second.object_value();
850
+ child_policy = Json::Array{
851
+ Json::Object{
852
+ {"ring_hash_experimental", ring_hash_experimental_policy},
853
+ },
854
+ };
839
855
  }
840
- // Construct locality-picking policy.
841
- // Start with field from our config and add the "targets" field.
842
- child_policy = Json::Array{
843
- Json::Object{
844
- {"weighted_target_experimental",
845
- Json::Object{
846
- {"targets", Json::Object()},
847
- }},
848
- },
849
- };
850
- Json::Object& config =
851
- *(*child_policy.mutable_array())[0].mutable_object();
852
- auto it = config.begin();
853
- GPR_ASSERT(it != config.end());
854
- (*it->second.mutable_object())["targets"] = std::move(weighted_targets);
856
+ }
857
+ // Wrap it in the drop policy.
858
+ Json::Array drop_categories;
859
+ if (discovery_entry.latest_update->drop_config != nullptr) {
860
+ for (const auto& category :
861
+ discovery_entry.latest_update->drop_config->drop_category_list()) {
862
+ drop_categories.push_back(Json::Object{
863
+ {"category", category.name},
864
+ {"requests_per_million", category.parts_per_million},
865
+ });
866
+ }
867
+ }
868
+ Json::Object xds_cluster_impl_config = {
869
+ {"clusterName", discovery_config.cluster_name},
870
+ {"childPolicy", std::move(child_policy)},
871
+ {"dropCategories", std::move(drop_categories)},
872
+ {"maxConcurrentRequests", discovery_config.max_concurrent_requests},
873
+ };
874
+ if (!discovery_config.eds_service_name.empty()) {
875
+ xds_cluster_impl_config["edsServiceName"] =
876
+ discovery_config.eds_service_name;
877
+ }
878
+ if (discovery_config.lrs_load_reporting_server.has_value()) {
879
+ xds_cluster_impl_config["lrsLoadReportingServer"] =
880
+ discovery_config.lrs_load_reporting_server->ToJson();
881
+ }
882
+ Json locality_picking_policy;
883
+ if (XdsOutlierDetectionEnabled()) {
884
+ Json::Object outlier_detection_config;
885
+ if (discovery_entry.config().outlier_detection_lb_config.has_value()) {
886
+ outlier_detection_config =
887
+ discovery_entry.config().outlier_detection_lb_config.value();
888
+ } else {
889
+ // outlier detection will be a no-op
890
+ outlier_detection_config["interval"] =
891
+ Duration::Infinity().ToJsonString();
892
+ }
893
+ outlier_detection_config["childPolicy"] = Json::Array{Json::Object{
894
+ {"xds_cluster_impl_experimental",
895
+ std::move(xds_cluster_impl_config)},
896
+ }};
897
+ locality_picking_policy = Json::Array{Json::Object{
898
+ {"outlier_detection_experimental",
899
+ std::move(outlier_detection_config)},
900
+ }};
855
901
  } else {
856
- auto it = xds_lb_policy.find("RING_HASH");
857
- GPR_ASSERT(it != xds_lb_policy.end());
858
- Json::Object ring_hash_experimental_policy = it->second.object_value();
859
- child_policy = Json::Array{
860
- Json::Object{
861
- {"ring_hash_experimental", ring_hash_experimental_policy},
862
- },
863
- };
902
+ locality_picking_policy = Json::Array{Json::Object{
903
+ {"xds_cluster_impl_experimental",
904
+ std::move(xds_cluster_impl_config)},
905
+ }};
864
906
  }
865
- }
866
- // Wrap it in the drop policy.
867
- Json::Array drop_categories;
868
- if (discovery_mechanisms_[discovery_index].drop_config != nullptr) {
869
- for (const auto& category : discovery_mechanisms_[discovery_index]
870
- .drop_config->drop_category_list()) {
871
- drop_categories.push_back(Json::Object{
872
- {"category", category.name},
873
- {"requests_per_million", category.parts_per_million},
874
- });
907
+ // Add priority entry, with the appropriate child name.
908
+ std::string child_name = discovery_entry.GetChildPolicyName(priority);
909
+ priority_priorities.emplace_back(child_name);
910
+ Json::Object child_config = {
911
+ {"config", std::move(locality_picking_policy)},
912
+ };
913
+ if (discovery_entry.discovery_mechanism->disable_reresolution()) {
914
+ child_config["ignore_reresolution_requests"] = true;
875
915
  }
876
- }
877
- const auto lrs_key = discovery_mechanisms_[discovery_index]
878
- .discovery_mechanism->GetLrsClusterKey();
879
- Json::Object xds_cluster_impl_config = {
880
- {"clusterName", std::string(lrs_key.first)},
881
- {"childPolicy", std::move(child_policy)},
882
- {"dropCategories", std::move(drop_categories)},
883
- {"maxConcurrentRequests",
884
- config_->discovery_mechanisms()[discovery_index]
885
- .max_concurrent_requests},
886
- };
887
- if (!lrs_key.second.empty()) {
888
- xds_cluster_impl_config["edsServiceName"] = std::string(lrs_key.second);
889
- }
890
- if (config_->discovery_mechanisms()[discovery_index]
891
- .lrs_load_reporting_server.has_value()) {
892
- xds_cluster_impl_config["lrsLoadReportingServer"] =
893
- config_->discovery_mechanisms()[discovery_index]
894
- .lrs_load_reporting_server->ToJson();
895
- }
896
- Json locality_picking_policy = Json::Array{Json::Object{
897
- {"xds_cluster_impl_experimental", std::move(xds_cluster_impl_config)},
898
- }};
899
- // Add priority entry.
900
- const size_t child_number = priority_child_numbers_[priority];
901
- std::string child_name = absl::StrCat("child", child_number);
902
- priority_priorities.emplace_back(child_name);
903
- Json::Object child_config = {
904
- {"config", std::move(locality_picking_policy)},
905
- };
906
- if (discovery_mechanisms_[discovery_index]
907
- .discovery_mechanism->disable_reresolution()) {
908
- child_config["ignore_reresolution_requests"] = true;
909
- }
910
- priority_children[child_name] = std::move(child_config);
911
- // Each priority in the priority_list_ should correspond to a priority in a
912
- // discovery mechanism in discovery_mechanisms_ (both in the same order).
913
- // Keeping track of the discovery_mechanism each priority belongs to.
914
- --num_priorities_remaining_in_discovery;
915
- while (num_priorities_remaining_in_discovery == 0 &&
916
- discovery_index < discovery_mechanisms_.size() - 1) {
917
- ++discovery_index;
918
- num_priorities_remaining_in_discovery =
919
- discovery_mechanisms_[discovery_index].num_priorities;
916
+ priority_children[child_name] = std::move(child_config);
920
917
  }
921
918
  }
922
- // There should be matching number of priorities in discovery_mechanisms_ and
923
- // in priority_list_; therefore at the end of looping through all the
924
- // priorities, num_priorities_remaining should be down to 0, and index should
925
- // be the last index in discovery_mechanisms_.
926
- GPR_ASSERT(num_priorities_remaining_in_discovery == 0);
927
- GPR_ASSERT(discovery_index == discovery_mechanisms_.size() - 1);
928
919
  Json json = Json::Array{Json::Object{
929
920
  {"priority_experimental",
930
921
  Json::Object{
@@ -1180,6 +1171,24 @@ class XdsClusterResolverLbFactory : public LoadBalancingPolicyFactory {
1180
1171
  gpr_parse_nonnegative_int(it->second.string_value().c_str());
1181
1172
  }
1182
1173
  }
1174
+ if (XdsOutlierDetectionEnabled()) {
1175
+ it = json.object_value().find("outlierDetection");
1176
+ if (it != json.object_value().end()) {
1177
+ if (it->second.type() != Json::Type::OBJECT) {
1178
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_STATIC_STRING(
1179
+ "field:outlierDetection error:type should be object"));
1180
+ } else {
1181
+ // No need to validate the contents of the outlier detection config,
1182
+ // because in this particular case, the JSON is generated by the CDS
1183
+ // policy instead of coming from service config, so it's not actually
1184
+ // any better to catch the problem here than it is to catch it in the
1185
+ // outlier_detection policy itself, so here we just act as a
1186
+ // pass-through.
1187
+ discovery_mechanism->outlier_detection_lb_config =
1188
+ it->second.object_value();
1189
+ }
1190
+ }
1191
+ }
1183
1192
  // Discovery Mechanism type
1184
1193
  it = json.object_value().find("type");
1185
1194
  if (it == json.object_value().end()) {