grpc 1.48.0 → 1.49.0.pre1

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 (715) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +104 -41
  3. data/include/grpc/event_engine/event_engine.h +19 -16
  4. data/include/grpc/impl/codegen/grpc_types.h +3 -8
  5. data/include/grpc/impl/codegen/port_platform.h +0 -8
  6. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +3 -3
  7. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +2 -2
  8. data/src/core/ext/filters/client_channel/client_channel.cc +117 -200
  9. data/src/core/ext/filters/client_channel/client_channel.h +15 -8
  10. data/src/core/ext/filters/client_channel/client_channel_factory.cc +0 -29
  11. data/src/core/ext/filters/client_channel/client_channel_factory.h +2 -10
  12. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
  13. data/src/core/ext/filters/client_channel/config_selector.h +12 -4
  14. data/src/core/ext/filters/client_channel/connector.h +4 -5
  15. data/src/core/ext/filters/client_channel/http_proxy.cc +53 -65
  16. data/src/core/ext/filters/client_channel/http_proxy.h +12 -9
  17. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +14 -12
  18. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +6 -6
  19. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +100 -124
  20. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +12 -3
  21. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +5 -1
  22. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +1 -0
  23. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -2
  24. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +1 -1
  25. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +169 -63
  26. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +25 -1
  27. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +15 -19
  28. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +66 -78
  29. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +44 -44
  30. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +6 -5
  31. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +65 -77
  32. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +15 -14
  33. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +19 -14
  34. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +60 -67
  35. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +40 -49
  36. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +81 -97
  37. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +53 -61
  38. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +171 -102
  39. data/src/core/ext/filters/client_channel/proxy_mapper.h +13 -14
  40. data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +19 -16
  41. data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +8 -7
  42. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +4 -8
  43. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +431 -145
  44. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +170 -99
  45. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +20 -7
  46. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +17 -15
  47. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +7 -17
  48. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +11 -0
  49. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +13 -14
  50. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +3 -4
  51. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +5 -6
  52. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +4 -13
  53. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +162 -165
  54. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +37 -30
  55. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +7 -10
  56. data/src/core/ext/filters/client_channel/retry_filter.cc +0 -7
  57. data/src/core/ext/filters/client_channel/retry_service_config.cc +30 -19
  58. data/src/core/ext/filters/client_channel/retry_service_config.h +6 -9
  59. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +6 -7
  60. data/src/core/ext/filters/client_channel/subchannel.cc +49 -89
  61. data/src/core/ext/filters/client_channel/subchannel.h +8 -8
  62. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +1 -1
  63. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +6 -76
  64. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +16 -25
  65. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +3 -4
  66. data/src/core/ext/filters/deadline/deadline_filter.cc +6 -6
  67. data/src/core/ext/filters/deadline/deadline_filter.h +2 -3
  68. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +1 -3
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +1 -1
  70. data/src/core/ext/filters/fault_injection/service_config_parser.cc +17 -12
  71. data/src/core/ext/filters/fault_injection/service_config_parser.h +4 -5
  72. data/src/core/ext/filters/http/client/http_client_filter.cc +2 -3
  73. data/src/core/ext/filters/http/client/http_client_filter.h +1 -1
  74. data/src/core/ext/filters/http/client_authority_filter.cc +1 -2
  75. data/src/core/ext/filters/http/client_authority_filter.h +1 -1
  76. data/src/core/ext/filters/http/server/http_server_filter.cc +2 -3
  77. data/src/core/ext/filters/http/server/http_server_filter.h +1 -1
  78. data/src/core/ext/filters/message_size/message_size_filter.cc +13 -7
  79. data/src/core/ext/filters/message_size/message_size_filter.h +3 -6
  80. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +16 -12
  81. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +4 -6
  82. data/src/core/ext/filters/server_config_selector/server_config_selector.h +5 -0
  83. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +3 -5
  84. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +35 -62
  85. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +62 -89
  86. data/src/core/ext/transport/chttp2/server/chttp2_server.h +4 -6
  87. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +130 -165
  88. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +3 -2
  89. data/src/core/ext/transport/chttp2/transport/flow_control.cc +67 -2
  90. data/src/core/ext/transport/chttp2/transport/flow_control.h +1 -0
  91. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +7 -1
  92. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +25 -8
  93. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +4 -0
  94. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +0 -1
  95. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +8 -2
  96. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +2 -10
  97. data/src/core/ext/transport/chttp2/transport/internal.h +2 -1
  98. data/src/core/ext/transport/inproc/inproc_transport.cc +40 -74
  99. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +5 -5
  100. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +30 -10
  101. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +4 -4
  102. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +24 -8
  103. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +8 -327
  104. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +83 -1723
  105. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +352 -0
  106. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +1768 -0
  107. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +2 -2
  108. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +12 -4
  109. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +6 -4
  110. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +33 -4
  111. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +1 -1
  112. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +6 -2
  113. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +1 -1
  114. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +6 -2
  115. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +6 -2
  116. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +12 -4
  117. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +1 -1
  118. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +6 -2
  119. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +1 -1
  120. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +7 -3
  121. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +14 -14
  122. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +90 -30
  123. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +21 -19
  124. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +124 -34
  125. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +3 -3
  126. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +18 -6
  127. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +23 -22
  128. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +153 -48
  129. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +1 -1
  130. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +6 -2
  131. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +1 -1
  132. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +6 -2
  133. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +11 -11
  134. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +84 -28
  135. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +7 -7
  136. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +42 -14
  137. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +1 -1
  138. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +6 -2
  139. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +25 -23
  140. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +156 -48
  141. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +7 -7
  142. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +42 -14
  143. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +1 -1
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +6 -2
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +1 -1
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +6 -2
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +2 -2
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +12 -4
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +12 -12
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +78 -26
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +9 -9
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +54 -18
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +1 -1
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +6 -2
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +21 -20
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +117 -44
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +1 -1
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +6 -2
  159. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +2 -2
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +12 -4
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +6 -2
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +1 -1
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +6 -2
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +1 -1
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +6 -2
  166. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +3 -3
  167. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +18 -6
  168. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +5 -5
  169. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +36 -12
  170. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +3 -3
  171. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +30 -10
  172. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +1 -1
  173. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +6 -2
  174. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +37 -13
  175. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +170 -15
  176. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +5 -5
  177. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +42 -14
  178. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +1 -1
  179. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +6 -2
  180. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +7 -4
  181. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +36 -4
  182. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +1 -1
  183. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +6 -2
  184. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +6 -6
  185. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +48 -16
  186. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +8 -8
  187. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +54 -18
  188. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +21 -9
  189. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +100 -14
  190. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +7 -22
  191. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +36 -77
  192. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +121 -76
  193. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +647 -163
  194. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +3 -3
  195. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +18 -6
  196. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +34 -15
  197. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +161 -22
  198. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +1 -1
  199. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +6 -2
  200. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +1 -1
  201. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +6 -2
  202. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +2 -2
  203. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +12 -4
  204. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +1 -1
  205. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +6 -2
  206. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +1 -1
  207. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +6 -2
  208. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +46 -0
  209. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +98 -0
  210. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +1 -1
  211. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +6 -2
  212. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +2 -2
  213. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +12 -4
  214. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +1 -0
  215. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +1 -0
  216. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +2 -2
  217. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +12 -4
  218. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +1 -1
  219. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +6 -2
  220. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +1 -1
  221. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +6 -2
  222. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +2 -2
  223. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +30 -10
  224. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +2 -2
  225. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +18 -6
  226. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +11 -4
  227. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +58 -4
  228. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +1 -1
  229. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +6 -2
  230. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +35 -27
  231. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +177 -52
  232. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +6 -2
  233. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +1 -1
  234. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +6 -2
  235. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +10 -8
  236. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +66 -14
  237. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +3 -3
  238. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +18 -6
  239. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +5 -5
  240. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +42 -14
  241. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +2 -2
  242. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +12 -4
  243. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +1 -1
  244. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +6 -2
  245. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +131 -16
  246. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +632 -12
  247. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +2 -2
  248. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +12 -4
  249. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +5 -5
  250. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +30 -10
  251. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +1 -1
  252. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +6 -2
  253. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +4 -4
  254. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +24 -8
  255. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +4 -4
  256. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +24 -8
  257. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +2 -2
  258. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +12 -4
  259. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +1 -1
  260. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +6 -2
  261. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +1 -1
  262. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +6 -2
  263. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +1 -1
  264. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +6 -2
  265. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +3 -3
  266. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +18 -6
  267. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +1 -1
  268. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +12 -4
  269. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +2 -2
  270. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +12 -4
  271. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +3 -3
  272. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +18 -6
  273. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +7 -7
  274. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +42 -14
  275. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +5 -5
  276. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +30 -10
  277. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +3 -3
  278. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +18 -6
  279. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +1 -1
  280. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +6 -2
  281. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +12 -4
  282. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +2 -2
  283. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +18 -6
  284. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +63 -0
  285. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +202 -0
  286. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +1 -1
  287. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +6 -2
  288. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +6 -2
  289. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -1
  290. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +11 -11
  291. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +66 -22
  292. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +9 -9
  293. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +72 -24
  294. data/src/core/ext/upb-generated/google/api/http.upb.c +3 -3
  295. data/src/core/ext/upb-generated/google/api/http.upb.h +18 -6
  296. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +1 -1
  297. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +6 -2
  298. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +1 -1
  299. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +6 -2
  300. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +44 -43
  301. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +177 -55
  302. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +1 -1
  303. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +6 -2
  304. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -1
  305. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +6 -2
  306. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +2 -2
  307. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +18 -6
  308. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +1 -1
  309. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +6 -2
  310. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +6 -6
  311. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +54 -18
  312. data/src/core/ext/upb-generated/google/rpc/status.upb.c +1 -1
  313. data/src/core/ext/upb-generated/google/rpc/status.upb.h +6 -2
  314. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +2 -2
  315. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +24 -8
  316. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +6 -2
  317. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +7 -7
  318. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +60 -20
  319. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +1 -1
  320. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +12 -4
  321. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +2 -2
  322. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +12 -4
  323. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +6 -6
  324. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +54 -18
  325. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +2 -2
  326. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +12 -4
  327. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +7 -7
  328. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +42 -14
  329. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +3 -3
  330. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +23 -11
  331. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +1 -1
  332. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +7 -3
  333. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +7 -3
  334. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +1 -1
  335. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +7 -3
  336. data/src/core/ext/upb-generated/validate/validate.upb.c +22 -22
  337. data/src/core/ext/upb-generated/validate/validate.upb.h +139 -47
  338. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +3 -3
  339. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +23 -11
  340. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +1 -1
  341. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +7 -3
  342. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +3 -3
  343. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +27 -11
  344. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +1 -1
  345. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +7 -3
  346. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +1 -1
  347. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +6 -2
  348. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +2 -2
  349. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +12 -4
  350. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +1 -1
  351. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +6 -2
  352. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +1 -1
  353. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +6 -2
  354. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +1 -1
  355. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +6 -2
  356. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +1 -1
  357. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +12 -4
  358. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +1 -1
  359. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +6 -2
  360. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +6 -2
  361. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +1 -1
  362. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +6 -2
  363. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +6 -6
  364. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +54 -18
  365. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +2 -2
  366. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +12 -4
  367. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +1 -1
  368. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +12 -4
  369. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +1 -1
  370. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +6 -2
  371. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +67 -274
  372. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +0 -85
  373. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +256 -0
  374. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +115 -0
  375. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +14 -11
  376. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +107 -107
  377. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +191 -187
  378. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +156 -154
  379. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +186 -183
  380. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +136 -134
  381. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +16 -16
  382. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +162 -139
  383. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +5 -0
  384. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +39 -31
  385. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +12 -8
  386. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +5 -0
  387. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +72 -75
  388. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +0 -5
  389. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +713 -670
  390. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +10 -0
  391. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +150 -139
  392. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +5 -0
  393. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +47 -0
  394. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +35 -0
  395. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +16 -12
  396. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +46 -25
  397. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +477 -466
  398. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +21 -18
  399. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +153 -84
  400. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +35 -0
  401. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +113 -113
  402. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +29 -28
  403. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +69 -0
  404. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +40 -0
  405. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +92 -90
  406. data/src/core/ext/xds/upb_utils.h +0 -21
  407. data/src/core/ext/xds/xds_api.cc +53 -86
  408. data/src/core/ext/xds/xds_api.h +19 -28
  409. data/src/core/ext/xds/xds_bootstrap.cc +39 -52
  410. data/src/core/ext/xds/xds_bootstrap.h +28 -8
  411. data/src/core/ext/xds/xds_certificate_provider.h +9 -0
  412. data/src/core/ext/xds/xds_channel_stack_modifier.cc +6 -4
  413. data/src/core/ext/xds/xds_channel_stack_modifier.h +8 -0
  414. data/src/core/ext/xds/xds_client.cc +555 -1214
  415. data/src/core/ext/xds/xds_client.h +16 -44
  416. data/src/core/ext/xds/xds_client_grpc.cc +291 -0
  417. data/src/core/ext/xds/xds_client_grpc.h +102 -0
  418. data/src/core/ext/xds/xds_cluster.cc +92 -103
  419. data/src/core/ext/xds/xds_cluster.h +6 -5
  420. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +10 -14
  421. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +1 -0
  422. data/src/core/ext/xds/xds_common_types.cc +134 -110
  423. data/src/core/ext/xds/xds_common_types.h +6 -7
  424. data/src/core/ext/xds/xds_endpoint.cc +80 -80
  425. data/src/core/ext/xds/xds_endpoint.h +4 -4
  426. data/src/core/ext/xds/xds_http_fault_filter.cc +4 -11
  427. data/src/core/ext/xds/xds_http_fault_filter.h +3 -3
  428. data/src/core/ext/xds/xds_http_filters.h +3 -3
  429. data/src/core/ext/xds/xds_http_rbac_filter.cc +39 -58
  430. data/src/core/ext/xds/xds_http_rbac_filter.h +3 -3
  431. data/src/core/ext/xds/xds_lb_policy_registry.cc +17 -20
  432. data/src/core/ext/xds/xds_lb_policy_registry.h +4 -4
  433. data/src/core/ext/xds/xds_listener.cc +329 -299
  434. data/src/core/ext/xds/xds_listener.h +4 -4
  435. data/src/core/ext/xds/xds_resource_type.h +13 -2
  436. data/src/core/ext/xds/xds_route_config.cc +180 -177
  437. data/src/core/ext/xds/xds_route_config.h +31 -17
  438. data/src/core/ext/xds/xds_routing.cc +3 -6
  439. data/src/core/ext/xds/xds_routing.h +7 -9
  440. data/src/core/ext/xds/xds_server_config_fetcher.cc +76 -81
  441. data/src/core/ext/xds/xds_transport.h +86 -0
  442. data/src/core/ext/xds/xds_transport_grpc.cc +349 -0
  443. data/src/core/ext/xds/xds_transport_grpc.h +135 -0
  444. data/src/core/lib/address_utils/parse_address.cc +19 -17
  445. data/src/core/lib/address_utils/parse_address.h +8 -5
  446. data/src/core/lib/avl/avl.h +47 -25
  447. data/src/core/lib/channel/call_tracer.h +1 -1
  448. data/src/core/lib/channel/channel_args.cc +88 -19
  449. data/src/core/lib/channel/channel_args.h +113 -62
  450. data/src/core/lib/channel/channel_stack.cc +0 -1
  451. data/src/core/lib/channel/channel_stack_builder.cc +3 -3
  452. data/src/core/lib/channel/channel_stack_builder.h +2 -2
  453. data/src/core/lib/channel/channel_stack_builder_impl.cc +2 -4
  454. data/src/core/lib/channel/channelz.cc +27 -37
  455. data/src/core/lib/channel/channelz.h +9 -0
  456. data/src/core/lib/channel/promise_based_filter.h +0 -1
  457. data/src/core/lib/config/core_configuration.h +48 -35
  458. data/src/core/lib/debug/stats.cc +12 -15
  459. data/src/core/lib/debug/stats.h +11 -3
  460. data/src/core/lib/event_engine/{event_engine.cc → default_event_engine.cc} +9 -5
  461. data/src/core/lib/event_engine/{event_engine_factory.h → default_event_engine.h} +4 -8
  462. data/src/core/lib/event_engine/default_event_engine_factory.cc +20 -3
  463. data/src/core/lib/event_engine/default_event_engine_factory.h +33 -0
  464. data/src/core/lib/event_engine/executor/executor.h +38 -0
  465. data/src/core/lib/event_engine/executor/threaded_executor.cc +36 -0
  466. data/src/core/lib/event_engine/executor/threaded_executor.h +44 -0
  467. data/src/core/lib/event_engine/forkable.cc +98 -0
  468. data/src/core/lib/event_engine/forkable.h +61 -0
  469. data/src/core/lib/event_engine/poller.h +54 -0
  470. data/src/core/lib/event_engine/{iomgr_engine/iomgr_engine.cc → posix_engine/posix_engine.cc} +30 -47
  471. data/src/core/lib/event_engine/{iomgr_engine/iomgr_engine.h → posix_engine/posix_engine.h} +27 -28
  472. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer.cc +4 -5
  473. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer.h +8 -8
  474. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_heap.cc +4 -4
  475. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_heap.h +5 -5
  476. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_manager.cc +46 -10
  477. data/src/core/lib/event_engine/{iomgr_engine → posix_engine}/timer_manager.h +17 -8
  478. data/src/core/lib/event_engine/promise.h +11 -2
  479. data/src/core/lib/event_engine/socket_notifier.h +55 -0
  480. data/src/core/lib/event_engine/{iomgr_engine/thread_pool.cc → thread_pool.cc} +49 -14
  481. data/src/core/lib/event_engine/{iomgr_engine/thread_pool.h → thread_pool.h} +21 -10
  482. data/src/core/lib/event_engine/utils.cc +49 -0
  483. data/src/core/lib/event_engine/utils.h +40 -0
  484. data/src/core/lib/event_engine/windows/iocp.cc +149 -0
  485. data/src/core/lib/event_engine/windows/iocp.h +68 -0
  486. data/src/core/lib/event_engine/windows/win_socket.cc +196 -0
  487. data/src/core/lib/event_engine/windows/win_socket.h +120 -0
  488. data/src/core/lib/event_engine/windows/windows_engine.cc +159 -0
  489. data/src/core/lib/event_engine/windows/windows_engine.h +120 -0
  490. data/src/core/lib/gpr/time.cc +11 -9
  491. data/src/core/lib/gpr/useful.h +29 -0
  492. data/src/core/lib/gprpp/bitset.h +3 -13
  493. data/src/core/lib/gprpp/debug_location.h +39 -7
  494. data/src/core/lib/gprpp/manual_constructor.h +0 -1
  495. data/src/core/lib/gprpp/no_destruct.h +94 -0
  496. data/src/core/lib/gprpp/ref_counted_ptr.h +0 -1
  497. data/src/core/lib/gprpp/status_helper.cc +1 -0
  498. data/src/core/lib/gprpp/table.h +0 -1
  499. data/src/core/lib/{event_engine/iomgr_engine → gprpp}/time_averaged_stats.cc +3 -5
  500. data/src/core/lib/{event_engine/iomgr_engine → gprpp}/time_averaged_stats.h +5 -7
  501. data/src/core/lib/{iomgr → gprpp}/work_serializer.cc +34 -18
  502. data/src/core/lib/{iomgr → gprpp}/work_serializer.h +21 -27
  503. data/src/core/lib/http/httpcli.cc +12 -24
  504. data/src/core/lib/http/httpcli_security_connector.cc +11 -11
  505. data/src/core/lib/iomgr/call_combiner.cc +0 -26
  506. data/src/core/lib/iomgr/closure.h +0 -9
  507. data/src/core/lib/iomgr/combiner.cc +0 -20
  508. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -1
  509. data/src/core/lib/iomgr/error.cc +0 -773
  510. data/src/core/lib/iomgr/error.h +0 -145
  511. data/src/core/lib/iomgr/error_cfstream.cc +0 -5
  512. data/src/core/lib/iomgr/ev_poll_posix.cc +17 -9
  513. data/src/core/lib/iomgr/exec_ctx.cc +0 -12
  514. data/src/core/lib/iomgr/executor.cc +0 -10
  515. data/src/core/lib/iomgr/executor.h +0 -3
  516. data/src/core/lib/iomgr/lockfree_event.cc +0 -17
  517. data/src/core/lib/iomgr/port.h +3 -0
  518. data/src/core/lib/iomgr/resolve_address.h +29 -6
  519. data/src/core/lib/iomgr/resolve_address_posix.cc +38 -8
  520. data/src/core/lib/iomgr/resolve_address_posix.h +19 -5
  521. data/src/core/lib/iomgr/resolve_address_windows.cc +40 -10
  522. data/src/core/lib/iomgr/resolve_address_windows.h +19 -5
  523. data/src/core/lib/iomgr/socket_windows.h +0 -2
  524. data/src/core/lib/iomgr/tcp_posix.cc +118 -6
  525. data/src/core/lib/iomgr/timer_generic.cc +6 -8
  526. data/src/core/lib/json/json.h +19 -22
  527. data/src/core/lib/json/json_args.h +34 -0
  528. data/src/core/lib/json/json_object_loader.cc +233 -0
  529. data/src/core/lib/json/json_object_loader.h +618 -0
  530. data/src/core/lib/json/json_reader.cc +86 -62
  531. data/src/core/lib/json/json_util.cc +8 -36
  532. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy.cc +3 -44
  533. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy.h +15 -24
  534. data/src/core/lib/load_balancing/lb_policy_factory.h +49 -0
  535. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy_registry.cc +49 -72
  536. data/src/core/{ext/filters/client_channel → lib/load_balancing}/lb_policy_registry.h +27 -27
  537. data/src/core/{ext/filters/client_channel → lib/load_balancing}/subchannel_interface.h +6 -6
  538. data/src/core/lib/promise/activity.h +56 -8
  539. data/src/core/lib/promise/arena_promise.h +84 -81
  540. data/src/core/lib/promise/context.h +0 -1
  541. data/src/core/lib/promise/detail/basic_seq.h +43 -23
  542. data/src/core/lib/promise/detail/promise_factory.h +0 -1
  543. data/src/core/lib/promise/map.h +0 -1
  544. data/src/core/lib/promise/seq.h +25 -4
  545. data/src/core/lib/promise/sleep.cc +38 -42
  546. data/src/core/lib/promise/sleep.h +27 -24
  547. data/src/core/lib/promise/try_seq.h +26 -6
  548. data/src/core/lib/resolver/resolver.cc +0 -47
  549. data/src/core/lib/resolver/resolver.h +2 -12
  550. data/src/core/lib/resolver/resolver_factory.h +2 -3
  551. data/src/core/lib/resolver/resolver_registry.cc +1 -1
  552. data/src/core/lib/resolver/resolver_registry.h +2 -3
  553. data/src/core/lib/resolver/server_address.cc +11 -15
  554. data/src/core/lib/resolver/server_address.h +4 -8
  555. data/src/core/lib/resource_quota/api.cc +1 -1
  556. data/src/core/lib/resource_quota/arena.cc +21 -1
  557. data/src/core/lib/resource_quota/arena.h +24 -2
  558. data/src/core/lib/resource_quota/memory_quota.cc +157 -17
  559. data/src/core/lib/resource_quota/memory_quota.h +98 -17
  560. data/src/core/lib/resource_quota/periodic_update.cc +79 -0
  561. data/src/core/lib/resource_quota/periodic_update.h +71 -0
  562. data/src/core/lib/security/authorization/evaluate_args.cc +10 -7
  563. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +1 -2
  564. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +1 -1
  565. data/src/core/lib/security/authorization/matchers.cc +13 -10
  566. data/src/core/lib/security/authorization/rbac_policy.cc +0 -1
  567. data/src/core/lib/security/credentials/alts/alts_credentials.cc +2 -3
  568. data/src/core/lib/security/credentials/alts/alts_credentials.h +3 -4
  569. data/src/core/lib/security/credentials/composite/composite_credentials.cc +3 -7
  570. data/src/core/lib/security/credentials/composite/composite_credentials.h +2 -4
  571. data/src/core/lib/security/credentials/credentials.h +16 -12
  572. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +18 -11
  573. data/src/core/lib/security/credentials/external/external_account_credentials.cc +32 -23
  574. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +5 -6
  575. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +4 -6
  576. data/src/core/lib/security/credentials/fake/fake_credentials.cc +3 -12
  577. data/src/core/lib/security/credentials/fake/fake_credentials.h +0 -4
  578. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +29 -26
  579. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +1 -3
  580. data/src/core/lib/security/credentials/iam/iam_credentials.cc +0 -1
  581. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +3 -3
  582. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +3 -4
  583. data/src/core/lib/security/credentials/jwt/json_token.cc +12 -3
  584. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +4 -8
  585. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +11 -13
  586. data/src/core/lib/security/credentials/local/local_credentials.cc +3 -4
  587. data/src/core/lib/security/credentials/local/local_credentials.h +3 -4
  588. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +17 -18
  589. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +0 -1
  590. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +13 -21
  591. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +3 -4
  592. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +6 -0
  593. data/src/core/lib/security/credentials/tls/tls_credentials.cc +13 -25
  594. data/src/core/lib/security/credentials/tls/tls_credentials.h +3 -4
  595. data/src/core/lib/security/credentials/xds/xds_credentials.cc +13 -30
  596. data/src/core/lib/security/credentials/xds/xds_credentials.h +3 -3
  597. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +10 -18
  598. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +26 -38
  599. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  600. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +5 -5
  601. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +6 -5
  602. data/src/core/lib/security/security_connector/local/local_security_connector.cc +13 -11
  603. data/src/core/lib/security/security_connector/local/local_security_connector.h +2 -2
  604. data/src/core/lib/security/security_connector/security_connector.h +5 -3
  605. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +5 -4
  606. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +5 -5
  607. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +5 -5
  608. data/src/core/lib/security/transport/auth_filters.h +1 -1
  609. data/src/core/lib/security/transport/client_auth_filter.cc +3 -4
  610. data/src/core/lib/security/transport/security_handshaker.cc +32 -44
  611. data/src/core/lib/security/transport/security_handshaker.h +2 -1
  612. data/src/core/lib/service_config/service_config.h +11 -0
  613. data/src/core/lib/service_config/service_config_impl.cc +98 -97
  614. data/src/core/lib/service_config/service_config_impl.h +11 -13
  615. data/src/core/lib/service_config/service_config_parser.cc +26 -27
  616. data/src/core/lib/service_config/service_config_parser.h +10 -22
  617. data/src/core/lib/slice/percent_encoding.cc +4 -13
  618. data/src/core/lib/slice/slice.cc +10 -4
  619. data/src/core/lib/surface/call.cc +8 -2
  620. data/src/core/lib/surface/channel.cc +6 -6
  621. data/src/core/lib/surface/channel.h +1 -1
  622. data/src/core/lib/surface/completion_queue.cc +0 -2
  623. data/src/core/lib/surface/completion_queue.h +0 -3
  624. data/src/core/lib/surface/init.cc +2 -6
  625. data/src/core/lib/surface/lame_client.cc +2 -3
  626. data/src/core/lib/surface/lame_client.h +1 -1
  627. data/src/core/lib/surface/server.cc +7 -12
  628. data/src/core/lib/surface/server.h +7 -7
  629. data/src/core/lib/surface/validate_metadata.cc +4 -14
  630. data/src/core/lib/surface/version.cc +2 -2
  631. data/src/core/lib/transport/connectivity_state.cc +0 -1
  632. data/src/core/lib/transport/connectivity_state.h +1 -1
  633. data/src/core/lib/transport/error_utils.cc +0 -36
  634. data/src/core/lib/transport/handshaker.cc +7 -9
  635. data/src/core/lib/transport/handshaker.h +4 -5
  636. data/src/core/lib/transport/handshaker_factory.h +2 -3
  637. data/src/core/lib/transport/handshaker_registry.cc +2 -1
  638. data/src/core/lib/transport/handshaker_registry.h +2 -4
  639. data/src/core/lib/transport/http_connect_handshaker.cc +16 -16
  640. data/src/core/lib/transport/metadata_batch.cc +5 -0
  641. data/src/core/lib/transport/metadata_batch.h +52 -7
  642. data/src/core/lib/transport/parsed_metadata.h +0 -1
  643. data/src/core/lib/transport/tcp_connect_handshaker.cc +12 -18
  644. data/src/core/lib/transport/transport.h +0 -7
  645. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +40 -21
  646. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +1 -1
  647. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +14 -7
  648. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker_private.h +1 -1
  649. data/src/core/tsi/fake_transport_security.cc +53 -30
  650. data/src/core/tsi/local_transport_security.cc +9 -5
  651. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +10 -1
  652. data/src/core/tsi/ssl_transport_security.cc +47 -23
  653. data/src/core/tsi/transport_security.cc +18 -6
  654. data/src/core/tsi/transport_security.h +2 -1
  655. data/src/core/tsi/transport_security_interface.h +17 -5
  656. data/src/ruby/ext/grpc/extconf.rb +2 -0
  657. data/src/ruby/ext/grpc/rb_loader.c +6 -2
  658. data/src/ruby/lib/grpc/version.rb +1 -1
  659. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +4 -0
  660. data/third_party/abseil-cpp/absl/functional/any_invocable.h +313 -0
  661. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +857 -0
  662. data/third_party/upb/third_party/utf8_range/utf8_range.h +1 -1
  663. data/third_party/upb/upb/arena.c +277 -0
  664. data/third_party/upb/upb/arena.h +225 -0
  665. data/third_party/upb/upb/array.c +114 -0
  666. data/third_party/upb/upb/array.h +83 -0
  667. data/third_party/upb/upb/collections.h +36 -0
  668. data/third_party/upb/upb/decode.c +161 -65
  669. data/third_party/upb/upb/decode.h +1 -0
  670. data/third_party/upb/upb/decode_fast.c +1 -1
  671. data/third_party/upb/upb/def.c +10 -2
  672. data/third_party/upb/upb/def.h +8 -1
  673. data/third_party/upb/upb/def.hpp +7 -4
  674. data/third_party/upb/upb/encode.c +29 -20
  675. data/third_party/upb/upb/encode.h +16 -6
  676. data/third_party/upb/upb/extension_registry.c +93 -0
  677. data/third_party/upb/upb/extension_registry.h +84 -0
  678. data/third_party/upb/upb/{decode_internal.h → internal/decode.h} +5 -5
  679. data/third_party/upb/upb/internal/table.h +385 -0
  680. data/third_party/upb/upb/{upb_internal.h → internal/upb.h} +3 -3
  681. data/third_party/upb/upb/internal/vsnprintf_compat.h +52 -0
  682. data/third_party/upb/upb/json_decode.c +1512 -0
  683. data/third_party/upb/upb/json_decode.h +47 -0
  684. data/third_party/upb/upb/json_encode.c +7 -3
  685. data/third_party/upb/upb/json_encode.h +6 -3
  686. data/third_party/upb/upb/map.c +108 -0
  687. data/third_party/upb/upb/map.h +117 -0
  688. data/third_party/upb/upb/message_value.h +66 -0
  689. data/third_party/upb/upb/mini_table.c +1147 -0
  690. data/third_party/upb/upb/mini_table.h +189 -0
  691. data/third_party/upb/upb/mini_table.hpp +112 -0
  692. data/third_party/upb/upb/msg.c +2 -62
  693. data/third_party/upb/upb/msg.h +2 -45
  694. data/third_party/upb/upb/msg_internal.h +28 -22
  695. data/third_party/upb/upb/port_def.inc +2 -1
  696. data/third_party/upb/upb/port_undef.inc +1 -0
  697. data/third_party/upb/upb/reflection.c +2 -159
  698. data/third_party/upb/upb/reflection.h +2 -112
  699. data/third_party/upb/upb/status.c +86 -0
  700. data/third_party/upb/upb/status.h +66 -0
  701. data/third_party/upb/upb/table.c +2 -2
  702. data/third_party/upb/upb/table_internal.h +3 -352
  703. data/third_party/upb/upb/text_encode.c +3 -2
  704. data/third_party/upb/upb/upb.c +4 -290
  705. data/third_party/upb/upb/upb.h +7 -196
  706. metadata +90 -38
  707. data/src/core/ext/filters/client_channel/lb_policy_factory.h +0 -50
  708. data/src/core/lib/iomgr/error_internal.h +0 -66
  709. data/src/core/lib/iomgr/executor/mpmcqueue.cc +0 -182
  710. data/src/core/lib/iomgr/executor/mpmcqueue.h +0 -171
  711. data/src/core/lib/iomgr/executor/threadpool.cc +0 -136
  712. data/src/core/lib/iomgr/executor/threadpool.h +0 -150
  713. data/src/core/lib/iomgr/time_averaged_stats.cc +0 -64
  714. data/src/core/lib/iomgr/time_averaged_stats.h +0 -72
  715. data/src/core/lib/promise/detail/switch.h +0 -1455
@@ -24,7 +24,6 @@
24
24
  #include <map>
25
25
  #include <memory>
26
26
  #include <string>
27
- #include <type_traits>
28
27
  #include <utility>
29
28
  #include <vector>
30
29
 
@@ -58,6 +57,7 @@
58
57
  #include "src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h"
59
58
  #include "src/core/ext/xds/xds_bootstrap.h"
60
59
  #include "src/core/ext/xds/xds_client.h"
60
+ #include "src/core/ext/xds/xds_client_grpc.h"
61
61
  #include "src/core/ext/xds/xds_http_filters.h"
62
62
  #include "src/core/ext/xds/xds_listener.h"
63
63
  #include "src/core/ext/xds/xds_resource_type_impl.h"
@@ -68,16 +68,16 @@
68
68
  #include "src/core/lib/channel/status_util.h"
69
69
  #include "src/core/lib/config/core_configuration.h"
70
70
  #include "src/core/lib/debug/trace.h"
71
- #include "src/core/lib/gpr/useful.h"
72
71
  #include "src/core/lib/gprpp/debug_location.h"
73
72
  #include "src/core/lib/gprpp/dual_ref_counted.h"
73
+ #include "src/core/lib/gprpp/match.h"
74
74
  #include "src/core/lib/gprpp/orphanable.h"
75
75
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
76
76
  #include "src/core/lib/gprpp/time.h"
77
+ #include "src/core/lib/gprpp/work_serializer.h"
77
78
  #include "src/core/lib/iomgr/error.h"
78
79
  #include "src/core/lib/iomgr/iomgr_fwd.h"
79
80
  #include "src/core/lib/iomgr/pollset_set.h"
80
- #include "src/core/lib/iomgr/work_serializer.h"
81
81
  #include "src/core/lib/resolver/resolver.h"
82
82
  #include "src/core/lib/resolver/resolver_factory.h"
83
83
  #include "src/core/lib/resolver/resolver_registry.h"
@@ -87,7 +87,6 @@
87
87
  #include "src/core/lib/service_config/service_config_call_data.h"
88
88
  #include "src/core/lib/service_config/service_config_impl.h"
89
89
  #include "src/core/lib/slice/slice_internal.h"
90
- #include "src/core/lib/transport/error_utils.h"
91
90
  #include "src/core/lib/transport/metadata_batch.h"
92
91
  #include "src/core/lib/uri/uri_parser.h"
93
92
 
@@ -112,11 +111,10 @@ std::string GetDefaultAuthorityInternal(const URI& uri) {
112
111
  return uri.path().substr(pos + 1);
113
112
  }
114
113
 
115
- std::string GetDataPlaneAuthority(const grpc_channel_args& args,
116
- const URI& uri) {
117
- const char* authority =
118
- grpc_channel_args_find_string(&args, GRPC_ARG_DEFAULT_AUTHORITY);
119
- if (authority != nullptr) return authority;
114
+ std::string GetDataPlaneAuthority(const ChannelArgs& args, const URI& uri) {
115
+ absl::optional<std::string> authority =
116
+ args.GetOwnedString(GRPC_ARG_DEFAULT_AUTHORITY);
117
+ if (authority.has_value()) return std::move(*authority);
120
118
  return GetDefaultAuthorityInternal(uri);
121
119
  }
122
120
 
@@ -129,10 +127,10 @@ class XdsResolver : public Resolver {
129
127
  explicit XdsResolver(ResolverArgs args)
130
128
  : work_serializer_(std::move(args.work_serializer)),
131
129
  result_handler_(std::move(args.result_handler)),
132
- args_(grpc_channel_args_copy(args.args)),
130
+ args_(std::move(args.args)),
133
131
  interested_parties_(args.pollset_set),
134
132
  uri_(std::move(args.uri)),
135
- data_plane_authority_(GetDataPlaneAuthority(*args.args, uri_)),
133
+ data_plane_authority_(GetDataPlaneAuthority(args_, uri_)),
136
134
  channel_id_(absl::Uniform<uint64_t>(absl::BitGen())) {
137
135
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_resolver_trace)) {
138
136
  gpr_log(
@@ -143,7 +141,6 @@ class XdsResolver : public Resolver {
143
141
  }
144
142
 
145
143
  ~XdsResolver() override {
146
- grpc_channel_args_destroy(args_);
147
144
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_resolver_trace)) {
148
145
  gpr_log(GPR_INFO, "[xds_resolver %p] destroyed", this);
149
146
  }
@@ -304,7 +301,7 @@ class XdsResolver : public Resolver {
304
301
  class XdsConfigSelector : public ConfigSelector {
305
302
  public:
306
303
  XdsConfigSelector(RefCountedPtr<XdsResolver> resolver,
307
- grpc_error_handle* error);
304
+ absl::Status* status);
308
305
  ~XdsConfigSelector() override;
309
306
 
310
307
  const char* name() const override { return "XdsConfigSelector"; }
@@ -322,7 +319,7 @@ class XdsResolver : public Resolver {
322
319
  return filters_;
323
320
  }
324
321
 
325
- grpc_channel_args* ModifyChannelArgs(grpc_channel_args* args) override;
322
+ ChannelArgs ModifyChannelArgs(const ChannelArgs& args) override;
326
323
 
327
324
  private:
328
325
  struct Route {
@@ -345,11 +342,10 @@ class XdsResolver : public Resolver {
345
342
  class RouteListIterator;
346
343
 
347
344
  void MaybeAddCluster(const std::string& name);
348
- grpc_error_handle CreateMethodConfig(
345
+ absl::StatusOr<RefCountedPtr<ServiceConfig>> CreateMethodConfig(
349
346
  const XdsRouteConfigResource::Route& route,
350
347
  const XdsRouteConfigResource::Route::RouteAction::ClusterWeight*
351
- cluster_weight,
352
- RefCountedPtr<ServiceConfig>* method_config);
348
+ cluster_weight);
353
349
 
354
350
  RefCountedPtr<XdsResolver> resolver_;
355
351
  RouteTable route_table_;
@@ -369,10 +365,10 @@ class XdsResolver : public Resolver {
369
365
 
370
366
  std::shared_ptr<WorkSerializer> work_serializer_;
371
367
  std::unique_ptr<ResultHandler> result_handler_;
372
- const grpc_channel_args* args_;
368
+ ChannelArgs args_;
373
369
  grpc_pollset_set* interested_parties_;
374
370
  URI uri_;
375
- RefCountedPtr<XdsClient> xds_client_;
371
+ RefCountedPtr<GrpcXdsClient> xds_client_;
376
372
  std::string lds_resource_name_;
377
373
  std::string data_plane_authority_;
378
374
  uint64_t channel_id_;
@@ -440,7 +436,7 @@ class XdsResolver::XdsConfigSelector::RouteListIterator
440
436
  //
441
437
 
442
438
  XdsResolver::XdsConfigSelector::XdsConfigSelector(
443
- RefCountedPtr<XdsResolver> resolver, grpc_error_handle* error)
439
+ RefCountedPtr<XdsResolver> resolver, absl::Status* status)
444
440
  : resolver_(std::move(resolver)) {
445
441
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_resolver_trace)) {
446
442
  gpr_log(GPR_INFO, "[xds_resolver %p] creating XdsConfigSelector %p",
@@ -475,45 +471,56 @@ XdsResolver::XdsConfigSelector::XdsConfigSelector(
475
471
  resolver_->current_listener_.http_connection_manager
476
472
  .http_max_stream_duration;
477
473
  }
478
- if (route_action->action.index() ==
479
- XdsRouteConfigResource::Route::RouteAction::kClusterIndex) {
480
- *error = CreateMethodConfig(route_entry.route, nullptr,
481
- &route_entry.method_config);
482
- MaybeAddCluster(absl::StrCat(
483
- "cluster:",
484
- absl::get<
485
- XdsRouteConfigResource::Route::RouteAction::kClusterIndex>(
486
- route_action->action)));
487
- } else if (route_action->action.index() ==
488
- XdsRouteConfigResource::Route::RouteAction::
489
- kWeightedClustersIndex) {
490
- auto& action_weighted_clusters = absl::get<
491
- XdsRouteConfigResource::Route::RouteAction::kWeightedClustersIndex>(
492
- route_action->action);
493
- uint32_t end = 0;
494
- for (const auto& weighted_cluster : action_weighted_clusters) {
495
- Route::ClusterWeightState cluster_weight_state;
496
- *error = CreateMethodConfig(route_entry.route, &weighted_cluster,
497
- &cluster_weight_state.method_config);
498
- if (!GRPC_ERROR_IS_NONE(*error)) return;
499
- end += weighted_cluster.weight;
500
- cluster_weight_state.range_end = end;
501
- cluster_weight_state.cluster = weighted_cluster.name;
502
- route_entry.weighted_cluster_state.push_back(
503
- std::move(cluster_weight_state));
504
- MaybeAddCluster(absl::StrCat("cluster:", weighted_cluster.name));
505
- }
506
- } else if (route_action->action.index() ==
507
- XdsRouteConfigResource::Route::RouteAction::
508
- kClusterSpecifierPluginIndex) {
509
- // cluster_specifier_plugin case:
510
- *error = CreateMethodConfig(route_entry.route, nullptr,
511
- &route_entry.method_config);
512
- MaybeAddCluster(absl::StrCat(
513
- "cluster_specifier_plugin:",
514
- absl::get<XdsRouteConfigResource::Route::RouteAction::
515
- kClusterSpecifierPluginIndex>(route_action->action)));
516
- }
474
+ Match(
475
+ route_action->action,
476
+ // cluster name
477
+ [&](const XdsRouteConfigResource::Route::RouteAction::ClusterName&
478
+ cluster_name) {
479
+ auto result = CreateMethodConfig(route_entry.route, nullptr);
480
+ if (!result.ok()) {
481
+ *status = result.status();
482
+ return;
483
+ }
484
+ route_entry.method_config = std::move(*result);
485
+ MaybeAddCluster(
486
+ absl::StrCat("cluster:", cluster_name.cluster_name));
487
+ },
488
+ // WeightedClusters
489
+ [&](const std::vector<
490
+ XdsRouteConfigResource::Route::RouteAction::ClusterWeight>&
491
+ weighted_clusters) {
492
+ uint32_t end = 0;
493
+ for (const auto& weighted_cluster : weighted_clusters) {
494
+ Route::ClusterWeightState cluster_weight_state;
495
+ auto result =
496
+ CreateMethodConfig(route_entry.route, &weighted_cluster);
497
+ if (!result.ok()) {
498
+ *status = result.status();
499
+ return;
500
+ }
501
+ cluster_weight_state.method_config = std::move(*result);
502
+ end += weighted_cluster.weight;
503
+ cluster_weight_state.range_end = end;
504
+ cluster_weight_state.cluster = weighted_cluster.name;
505
+ route_entry.weighted_cluster_state.push_back(
506
+ std::move(cluster_weight_state));
507
+ MaybeAddCluster(absl::StrCat("cluster:", weighted_cluster.name));
508
+ }
509
+ },
510
+ // ClusterSpecifierPlugin
511
+ [&](const XdsRouteConfigResource::Route::RouteAction::
512
+ ClusterSpecifierPluginName& cluster_specifier_plugin_name) {
513
+ auto result = CreateMethodConfig(route_entry.route, nullptr);
514
+ if (!result.ok()) {
515
+ *status = result.status();
516
+ return;
517
+ }
518
+ route_entry.method_config = std::move(*result);
519
+ MaybeAddCluster(absl::StrCat(
520
+ "cluster_specifier_plugin:",
521
+ cluster_specifier_plugin_name.cluster_specifier_plugin_name));
522
+ });
523
+ if (!status->ok()) return;
517
524
  }
518
525
  }
519
526
  // Populate filter list.
@@ -541,11 +548,11 @@ XdsResolver::XdsConfigSelector::~XdsConfigSelector() {
541
548
  resolver_->MaybeRemoveUnusedClusters();
542
549
  }
543
550
 
544
- grpc_error_handle XdsResolver::XdsConfigSelector::CreateMethodConfig(
551
+ absl::StatusOr<RefCountedPtr<ServiceConfig>>
552
+ XdsResolver::XdsConfigSelector::CreateMethodConfig(
545
553
  const XdsRouteConfigResource::Route& route,
546
554
  const XdsRouteConfigResource::Route::RouteAction::ClusterWeight*
547
- cluster_weight,
548
- RefCountedPtr<ServiceConfig>* method_config) {
555
+ cluster_weight) {
549
556
  std::vector<std::string> fields;
550
557
  const auto& route_action =
551
558
  absl::get<XdsRouteConfigResource::Route::RouteAction>(route.action);
@@ -594,21 +601,17 @@ grpc_error_handle XdsResolver::XdsConfigSelector::CreateMethodConfig(
594
601
  route_action.max_stream_duration->ToJsonString()));
595
602
  }
596
603
  // Handle xDS HTTP filters.
597
- XdsRouting::GeneratePerHttpFilterConfigsResult result =
598
- XdsRouting::GeneratePerHTTPFilterConfigs(
599
- resolver_->current_listener_.http_connection_manager.http_filters,
600
- resolver_->current_virtual_host_, route, cluster_weight,
601
- grpc_channel_args_copy(resolver_->args_));
602
- if (!GRPC_ERROR_IS_NONE(result.error)) {
603
- return result.error;
604
- }
605
- for (const auto& p : result.per_filter_configs) {
604
+ auto result = XdsRouting::GeneratePerHTTPFilterConfigs(
605
+ resolver_->current_listener_.http_connection_manager.http_filters,
606
+ resolver_->current_virtual_host_, route, cluster_weight,
607
+ resolver_->args_);
608
+ if (!result.ok()) return result.status();
609
+ for (const auto& p : result->per_filter_configs) {
606
610
  fields.emplace_back(absl::StrCat(" \"", p.first, "\": [\n",
607
611
  absl::StrJoin(p.second, ",\n"),
608
612
  "\n ]"));
609
613
  }
610
614
  // Construct service config.
611
- grpc_error_handle error = GRPC_ERROR_NONE;
612
615
  if (!fields.empty()) {
613
616
  std::string json = absl::StrCat(
614
617
  "{\n"
@@ -620,15 +623,13 @@ grpc_error_handle XdsResolver::XdsConfigSelector::CreateMethodConfig(
620
623
  absl::StrJoin(fields, ",\n"),
621
624
  "\n } ]\n"
622
625
  "}");
623
- *method_config =
624
- ServiceConfigImpl::Create(result.args, json.c_str(), &error);
626
+ return ServiceConfigImpl::Create(result->args, json.c_str());
625
627
  }
626
- grpc_channel_args_destroy(result.args);
627
- return error;
628
+ return nullptr;
628
629
  }
629
630
 
630
- grpc_channel_args* XdsResolver::XdsConfigSelector::ModifyChannelArgs(
631
- grpc_channel_args* args) {
631
+ ChannelArgs XdsResolver::XdsConfigSelector::ModifyChannelArgs(
632
+ const ChannelArgs& args) {
632
633
  return args;
633
634
  }
634
635
 
@@ -682,58 +683,60 @@ ConfigSelector::CallConfig XdsResolver::XdsConfigSelector::GetCallConfig(
682
683
  &entry.route.action);
683
684
  if (route_action == nullptr) {
684
685
  CallConfig call_config;
685
- call_config.error =
686
- grpc_error_set_int(GRPC_ERROR_CREATE_FROM_STATIC_STRING(
687
- "Matching route has inappropriate action"),
688
- GRPC_ERROR_INT_GRPC_STATUS, GRPC_STATUS_UNAVAILABLE);
686
+ call_config.status =
687
+ absl::UnavailableError("Matching route has inappropriate action");
689
688
  return call_config;
690
689
  }
691
690
  std::string cluster_name;
692
691
  RefCountedPtr<ServiceConfig> method_config;
693
- if (route_action->action.index() ==
694
- XdsRouteConfigResource::Route::RouteAction::kClusterIndex) {
695
- cluster_name = absl::StrCat(
696
- "cluster:",
697
- absl::get<XdsRouteConfigResource::Route::RouteAction::kClusterIndex>(
698
- route_action->action));
699
- method_config = entry.method_config;
700
- } else if (route_action->action.index() ==
701
- XdsRouteConfigResource::Route::RouteAction::
702
- kWeightedClustersIndex) {
703
- const uint32_t key =
704
- rand() %
705
- entry.weighted_cluster_state[entry.weighted_cluster_state.size() - 1]
706
- .range_end;
707
- // Find the index in weighted clusters corresponding to key.
708
- size_t mid = 0;
709
- size_t start_index = 0;
710
- size_t end_index = entry.weighted_cluster_state.size() - 1;
711
- size_t index = 0;
712
- while (end_index > start_index) {
713
- mid = (start_index + end_index) / 2;
714
- if (entry.weighted_cluster_state[mid].range_end > key) {
715
- end_index = mid;
716
- } else if (entry.weighted_cluster_state[mid].range_end < key) {
717
- start_index = mid + 1;
718
- } else {
719
- index = mid + 1;
720
- break;
721
- }
722
- }
723
- if (index == 0) index = start_index;
724
- GPR_ASSERT(entry.weighted_cluster_state[index].range_end > key);
725
- cluster_name =
726
- absl::StrCat("cluster:", entry.weighted_cluster_state[index].cluster);
727
- method_config = entry.weighted_cluster_state[index].method_config;
728
- } else if (route_action->action.index() ==
729
- XdsRouteConfigResource::Route::RouteAction::
730
- kClusterSpecifierPluginIndex) {
731
- cluster_name = absl::StrCat(
732
- "cluster_specifier_plugin:",
733
- absl::get<XdsRouteConfigResource::Route::RouteAction::
734
- kClusterSpecifierPluginIndex>(route_action->action));
735
- method_config = entry.method_config;
736
- }
692
+ Match(
693
+ route_action->action,
694
+ // cluster name
695
+ [&](const XdsRouteConfigResource::Route::RouteAction::ClusterName&
696
+ action_cluster_name) {
697
+ cluster_name =
698
+ absl::StrCat("cluster:", action_cluster_name.cluster_name);
699
+ method_config = entry.method_config;
700
+ },
701
+ // WeightedClusters
702
+ [&](const std::vector<
703
+ XdsRouteConfigResource::Route::RouteAction::ClusterWeight>&
704
+ /*weighted_clusters*/) {
705
+ const uint32_t key =
706
+ rand() %
707
+ entry
708
+ .weighted_cluster_state[entry.weighted_cluster_state.size() - 1]
709
+ .range_end;
710
+ // Find the index in weighted clusters corresponding to key.
711
+ size_t mid = 0;
712
+ size_t start_index = 0;
713
+ size_t end_index = entry.weighted_cluster_state.size() - 1;
714
+ size_t index = 0;
715
+ while (end_index > start_index) {
716
+ mid = (start_index + end_index) / 2;
717
+ if (entry.weighted_cluster_state[mid].range_end > key) {
718
+ end_index = mid;
719
+ } else if (entry.weighted_cluster_state[mid].range_end < key) {
720
+ start_index = mid + 1;
721
+ } else {
722
+ index = mid + 1;
723
+ break;
724
+ }
725
+ }
726
+ if (index == 0) index = start_index;
727
+ GPR_ASSERT(entry.weighted_cluster_state[index].range_end > key);
728
+ cluster_name = absl::StrCat(
729
+ "cluster:", entry.weighted_cluster_state[index].cluster);
730
+ method_config = entry.weighted_cluster_state[index].method_config;
731
+ },
732
+ // ClusterSpecifierPlugin
733
+ [&](const XdsRouteConfigResource::Route::RouteAction::
734
+ ClusterSpecifierPluginName& cluster_specifier_plugin_name) {
735
+ cluster_name = absl::StrCat(
736
+ "cluster_specifier_plugin:",
737
+ cluster_specifier_plugin_name.cluster_specifier_plugin_name);
738
+ method_config = entry.method_config;
739
+ });
737
740
  auto it = clusters_.find(cluster_name);
738
741
  GPR_ASSERT(it != clusters_.end());
739
742
  // Generate a hash.
@@ -790,24 +793,22 @@ ConfigSelector::CallConfig XdsResolver::XdsConfigSelector::GetCallConfig(
790
793
 
791
794
  void XdsResolver::StartLocked() {
792
795
  grpc_error_handle error = GRPC_ERROR_NONE;
793
- xds_client_ = XdsClient::GetOrCreate(args_, &error);
794
- if (!GRPC_ERROR_IS_NONE(error)) {
796
+ auto xds_client = GrpcXdsClient::GetOrCreate(args_, "xds resolver");
797
+ if (!xds_client.ok()) {
795
798
  gpr_log(GPR_ERROR,
796
799
  "Failed to create xds client -- channel will remain in "
797
800
  "TRANSIENT_FAILURE: %s",
798
- grpc_error_std_string(error).c_str());
799
- std::string error_message;
800
- grpc_error_get_str(error, GRPC_ERROR_STR_DESCRIPTION, &error_message);
801
- absl::Status status = absl::UnavailableError(
802
- absl::StrCat("Failed to create XdsClient: ", error_message));
801
+ xds_client.status().ToString().c_str());
802
+ absl::Status status = absl::UnavailableError(absl::StrCat(
803
+ "Failed to create XdsClient: ", xds_client.status().message()));
803
804
  Result result;
804
805
  result.addresses = status;
805
806
  result.service_config = std::move(status);
806
- result.args = grpc_channel_args_copy(args_);
807
+ result.args = args_;
807
808
  result_handler_->ReportResult(std::move(result));
808
- GRPC_ERROR_UNREF(error);
809
809
  return;
810
810
  }
811
+ xds_client_ = std::move(*xds_client);
811
812
  std::string resource_name_fragment(absl::StripPrefix(uri_.path(), "/"));
812
813
  if (!uri_.authority().empty()) {
813
814
  // target_uri.authority is set case
@@ -820,7 +821,7 @@ void XdsResolver::StartLocked() {
820
821
  Result result;
821
822
  result.addresses = status;
822
823
  result.service_config = std::move(status);
823
- result.args = grpc_channel_args_copy(args_);
824
+ result.args = args_;
824
825
  result_handler_->ReportResult(std::move(result));
825
826
  return;
826
827
  }
@@ -852,8 +853,9 @@ void XdsResolver::StartLocked() {
852
853
  gpr_log(GPR_INFO, "[xds_resolver %p] Started with lds_resource_name %s.",
853
854
  this, lds_resource_name_.c_str());
854
855
  }
855
- grpc_pollset_set_add_pollset_set(xds_client_->interested_parties(),
856
- interested_parties_);
856
+ grpc_pollset_set_add_pollset_set(
857
+ static_cast<GrpcXdsClient*>(xds_client_.get())->interested_parties(),
858
+ interested_parties_);
857
859
  auto watcher = MakeRefCounted<ListenerWatcher>(Ref());
858
860
  listener_watcher_ = watcher.get();
859
861
  XdsListenerResourceType::StartWatch(xds_client_.get(), lds_resource_name_,
@@ -875,9 +877,10 @@ void XdsResolver::ShutdownLocked() {
875
877
  xds_client_.get(), route_config_name_, route_config_watcher_,
876
878
  /*delay_unsubscription=*/false);
877
879
  }
878
- grpc_pollset_set_del_pollset_set(xds_client_->interested_parties(),
879
- interested_parties_);
880
- xds_client_.reset();
880
+ grpc_pollset_set_del_pollset_set(
881
+ static_cast<GrpcXdsClient*>(xds_client_.get())->interested_parties(),
882
+ interested_parties_);
883
+ xds_client_.reset(DEBUG_LOCATION, "xds resolver");
881
884
  }
882
885
  }
883
886
 
@@ -975,8 +978,11 @@ void XdsResolver::OnError(absl::string_view context, absl::Status status) {
975
978
  Result result;
976
979
  result.addresses = status;
977
980
  result.service_config = std::move(status);
978
- grpc_arg new_arg = xds_client_->MakeChannelArg();
979
- result.args = grpc_channel_args_copy_and_add(args_, &new_arg, 1);
981
+ // Need to explicitly convert to the right RefCountedPtr<> type for
982
+ // use with ChannelArgs::SetObject().
983
+ RefCountedPtr<GrpcXdsClient> xds_client =
984
+ xds_client_->Ref(DEBUG_LOCATION, "xds resolver result");
985
+ result.args = args_.SetObject(std::move(xds_client));
980
986
  result_handler_->ReportResult(std::move(result));
981
987
  }
982
988
 
@@ -991,11 +997,10 @@ void XdsResolver::OnResourceDoesNotExist(std::string context) {
991
997
  current_virtual_host_.routes.clear();
992
998
  Result result;
993
999
  result.addresses.emplace();
994
- grpc_error_handle error = GRPC_ERROR_NONE;
995
- result.service_config = ServiceConfigImpl::Create(args_, "{}", &error);
996
- GPR_ASSERT(*result.service_config != nullptr);
1000
+ result.service_config = ServiceConfigImpl::Create(args_, "{}");
1001
+ GPR_ASSERT(result.service_config.ok());
997
1002
  result.resolution_note = std::move(context);
998
- result.args = grpc_channel_args_copy(args_);
1003
+ result.args = args_;
999
1004
  result_handler_->ReportResult(std::move(result));
1000
1005
  }
1001
1006
 
@@ -1037,26 +1042,18 @@ XdsResolver::CreateServiceConfig() {
1037
1042
  " ]\n"
1038
1043
  "}");
1039
1044
  std::string json = absl::StrJoin(config_parts, "");
1040
- grpc_error_handle error = GRPC_ERROR_NONE;
1041
- absl::StatusOr<RefCountedPtr<ServiceConfig>> result =
1042
- ServiceConfigImpl::Create(args_, json.c_str(), &error);
1043
- if (!GRPC_ERROR_IS_NONE(error)) {
1044
- result = grpc_error_to_absl_status(error);
1045
- GRPC_ERROR_UNREF(error);
1046
- }
1047
- return result;
1045
+ return ServiceConfigImpl::Create(args_, json.c_str());
1048
1046
  }
1049
1047
 
1050
1048
  void XdsResolver::GenerateResult() {
1051
1049
  if (current_virtual_host_.routes.empty()) return;
1052
1050
  // First create XdsConfigSelector, which may add new entries to the cluster
1053
1051
  // state map, and then CreateServiceConfig for LB policies.
1054
- grpc_error_handle error = GRPC_ERROR_NONE;
1055
- auto config_selector = MakeRefCounted<XdsConfigSelector>(Ref(), &error);
1056
- if (!GRPC_ERROR_IS_NONE(error)) {
1052
+ absl::Status status;
1053
+ auto config_selector = MakeRefCounted<XdsConfigSelector>(Ref(), &status);
1054
+ if (!status.ok()) {
1057
1055
  OnError("could not create ConfigSelector",
1058
- absl::UnavailableError(grpc_error_std_string(error)));
1059
- GRPC_ERROR_UNREF(error);
1056
+ absl::UnavailableError(status.message()));
1060
1057
  return;
1061
1058
  }
1062
1059
  Result result;
@@ -1068,12 +1065,12 @@ void XdsResolver::GenerateResult() {
1068
1065
  ? std::string((*result.service_config)->json_string()).c_str()
1069
1066
  : result.service_config.status().ToString().c_str());
1070
1067
  }
1071
- grpc_arg new_args[] = {
1072
- xds_client_->MakeChannelArg(),
1073
- config_selector->MakeChannelArg(),
1074
- };
1068
+ // Need to explicitly convert to the right RefCountedPtr<> type for
1069
+ // use with ChannelArgs::SetObject().
1070
+ RefCountedPtr<GrpcXdsClient> xds_client =
1071
+ xds_client_->Ref(DEBUG_LOCATION, "xds resolver result");
1075
1072
  result.args =
1076
- grpc_channel_args_copy_and_add(args_, new_args, GPR_ARRAY_SIZE(new_args));
1073
+ args_.SetObject(std::move(xds_client)).SetObject(config_selector);
1077
1074
  result_handler_->ReportResult(std::move(result));
1078
1075
  }
1079
1076
 
@@ -25,13 +25,16 @@
25
25
  #include <vector>
26
26
 
27
27
  #include "absl/memory/memory.h"
28
+ #include "absl/status/status.h"
29
+ #include "absl/status/statusor.h"
28
30
  #include "absl/strings/str_cat.h"
29
31
  #include "absl/types/optional.h"
30
32
 
31
33
  #include <grpc/support/log.h>
32
34
 
33
- #include "src/core/ext/filters/client_channel/lb_policy_registry.h"
35
+ #include "src/core/lib/iomgr/error.h"
34
36
  #include "src/core/lib/json/json_util.h"
37
+ #include "src/core/lib/load_balancing/lb_policy_registry.h"
35
38
 
36
39
  // As per the retry design, we do not allow more than 5 retry attempts.
37
40
  #define MAX_MAX_RETRY_ATTEMPTS 5
@@ -78,24 +81,21 @@ absl::optional<std::string> ParseHealthCheckConfig(const Json& field,
78
81
 
79
82
  } // namespace
80
83
 
81
- std::unique_ptr<ServiceConfigParser::ParsedConfig>
82
- ClientChannelServiceConfigParser::ParseGlobalParams(
83
- const grpc_channel_args* /*args*/, const Json& json,
84
- grpc_error_handle* error) {
85
- GPR_DEBUG_ASSERT(error != nullptr && GRPC_ERROR_IS_NONE(*error));
84
+ absl::StatusOr<std::unique_ptr<ServiceConfigParser::ParsedConfig>>
85
+ ClientChannelServiceConfigParser::ParseGlobalParams(const ChannelArgs& /*args*/,
86
+ const Json& json) {
86
87
  std::vector<grpc_error_handle> error_list;
87
88
  // Parse LB config.
88
89
  RefCountedPtr<LoadBalancingPolicy::Config> parsed_lb_config;
89
90
  auto it = json.object_value().find("loadBalancingConfig");
90
91
  if (it != json.object_value().end()) {
91
- grpc_error_handle parse_error = GRPC_ERROR_NONE;
92
- parsed_lb_config = LoadBalancingPolicyRegistry::ParseLoadBalancingConfig(
93
- it->second, &parse_error);
94
- if (!GRPC_ERROR_IS_NONE(parse_error)) {
95
- std::vector<grpc_error_handle> lb_errors;
96
- lb_errors.push_back(parse_error);
97
- error_list.push_back(GRPC_ERROR_CREATE_FROM_VECTOR(
98
- "field:loadBalancingConfig", &lb_errors));
92
+ auto config =
93
+ LoadBalancingPolicyRegistry::ParseLoadBalancingConfig(it->second);
94
+ if (!config.ok()) {
95
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrCat(
96
+ "field:loadBalancingConfig error:", config.status().message())));
97
+ } else {
98
+ parsed_lb_config = std::move(*config);
99
99
  }
100
100
  }
101
101
  // Parse deprecated LB policy.
@@ -134,21 +134,23 @@ ClientChannelServiceConfigParser::ParseGlobalParams(
134
134
  error_list.push_back(parsing_error);
135
135
  }
136
136
  }
137
- *error = GRPC_ERROR_CREATE_FROM_VECTOR("Client channel global parser",
138
- &error_list);
139
- if (GRPC_ERROR_IS_NONE(*error)) {
140
- return absl::make_unique<ClientChannelGlobalParsedConfig>(
141
- std::move(parsed_lb_config), std::move(lb_policy_name),
142
- std::move(health_check_service_name));
137
+ if (!error_list.empty()) {
138
+ grpc_error_handle error = GRPC_ERROR_CREATE_FROM_VECTOR(
139
+ "Client channel global parser", &error_list);
140
+ absl::Status status = absl::InvalidArgumentError(
141
+ absl::StrCat("error parsing client channel global parameters: ",
142
+ grpc_error_std_string(error)));
143
+ GRPC_ERROR_UNREF(error);
144
+ return status;
143
145
  }
144
- return nullptr;
146
+ return absl::make_unique<ClientChannelGlobalParsedConfig>(
147
+ std::move(parsed_lb_config), std::move(lb_policy_name),
148
+ std::move(health_check_service_name));
145
149
  }
146
150
 
147
- std::unique_ptr<ServiceConfigParser::ParsedConfig>
151
+ absl::StatusOr<std::unique_ptr<ServiceConfigParser::ParsedConfig>>
148
152
  ClientChannelServiceConfigParser::ParsePerMethodParams(
149
- const grpc_channel_args* /*args*/, const Json& json,
150
- grpc_error_handle* error) {
151
- GPR_DEBUG_ASSERT(error != nullptr && GRPC_ERROR_IS_NONE(*error));
153
+ const ChannelArgs& /*args*/, const Json& json) {
152
154
  std::vector<grpc_error_handle> error_list;
153
155
  // Parse waitForReady.
154
156
  absl::optional<bool> wait_for_ready;
@@ -168,12 +170,17 @@ ClientChannelServiceConfigParser::ParsePerMethodParams(
168
170
  ParseJsonObjectFieldAsDuration(json.object_value(), "timeout", &timeout,
169
171
  &error_list, false);
170
172
  // Return result.
171
- *error = GRPC_ERROR_CREATE_FROM_VECTOR("Client channel parser", &error_list);
172
- if (GRPC_ERROR_IS_NONE(*error)) {
173
- return absl::make_unique<ClientChannelMethodParsedConfig>(timeout,
174
- wait_for_ready);
173
+ if (!error_list.empty()) {
174
+ grpc_error_handle error =
175
+ GRPC_ERROR_CREATE_FROM_VECTOR("Client channel parser", &error_list);
176
+ absl::Status status = absl::InvalidArgumentError(
177
+ absl::StrCat("error parsing client channel method parameters: ",
178
+ grpc_error_std_string(error)));
179
+ GRPC_ERROR_UNREF(error);
180
+ return status;
175
181
  }
176
- return nullptr;
182
+ return absl::make_unique<ClientChannelMethodParsedConfig>(timeout,
183
+ wait_for_ready);
177
184
  }
178
185
 
179
186
  } // namespace internal