grpc 1.49.0.pre1-x86_64-linux → 1.50.0.pre1-x86_64-linux

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 (277) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +54 -153
  3. data/include/grpc/event_engine/endpoint_config.h +11 -5
  4. data/include/grpc/event_engine/event_engine.h +1 -1
  5. data/include/grpc/impl/codegen/atm_gcc_atomic.h +19 -28
  6. data/include/grpc/impl/codegen/atm_gcc_sync.h +0 -2
  7. data/include/grpc/impl/codegen/atm_windows.h +0 -2
  8. data/include/grpc/impl/codegen/grpc_types.h +6 -0
  9. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +3 -3
  10. data/src/core/ext/filters/client_channel/backup_poller.cc +4 -6
  11. data/src/core/ext/filters/client_channel/client_channel.cc +41 -22
  12. data/src/core/ext/filters/client_channel/client_channel.h +1 -1
  13. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +0 -16
  14. data/src/core/ext/filters/client_channel/http_proxy.cc +12 -19
  15. data/src/core/ext/filters/client_channel/http_proxy.h +3 -2
  16. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +6 -4
  17. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +5 -4
  18. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +0 -2
  19. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +114 -103
  20. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +20 -11
  21. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +106 -108
  22. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +16 -0
  23. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +20 -13
  24. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +165 -257
  25. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +218 -231
  26. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +10 -6
  27. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +389 -444
  28. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +16 -16
  29. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +8 -13
  30. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +87 -96
  31. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +38 -37
  32. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +106 -186
  33. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +106 -93
  34. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +170 -218
  35. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +2 -2
  36. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +1 -1
  37. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +38 -18
  38. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +84 -37
  39. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +11 -0
  40. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -0
  41. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +5 -3
  42. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +5 -4
  43. data/src/core/ext/filters/client_channel/retry_filter.cc +25 -29
  44. data/src/core/ext/filters/client_channel/subchannel.cc +38 -33
  45. data/src/core/ext/filters/client_channel/subchannel.h +12 -3
  46. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +1 -2
  47. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +23 -16
  48. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +8 -0
  49. data/src/core/ext/filters/http/client/http_client_filter.cc +1 -2
  50. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +2 -4
  51. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +0 -2
  52. data/src/core/ext/filters/http/server/http_server_filter.cc +1 -2
  53. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +12 -8
  54. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +32 -26
  55. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +1 -1
  56. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +25 -130
  57. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +287 -0
  58. data/src/core/ext/transport/chttp2/transport/decode_huff.h +1018 -0
  59. data/src/core/ext/transport/chttp2/transport/flow_control.cc +83 -51
  60. data/src/core/ext/transport/chttp2/transport/flow_control.h +11 -6
  61. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +1 -2
  62. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +2 -20
  63. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +28 -28
  64. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +1 -10
  65. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +11 -6
  66. data/src/core/ext/transport/chttp2/transport/internal.h +2 -0
  67. data/src/core/ext/transport/chttp2/transport/parsing.cc +44 -0
  68. data/src/core/ext/transport/chttp2/transport/writing.cc +3 -14
  69. data/src/core/ext/transport/inproc/inproc_transport.cc +1 -3
  70. data/src/core/ext/xds/certificate_provider_store.cc +63 -3
  71. data/src/core/ext/xds/certificate_provider_store.h +9 -1
  72. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +5 -5
  73. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +1 -1
  74. data/src/core/ext/xds/xds_api.cc +21 -17
  75. data/src/core/ext/xds/xds_api.h +7 -0
  76. data/src/core/ext/xds/xds_bootstrap.cc +5 -537
  77. data/src/core/ext/xds/xds_bootstrap.h +39 -111
  78. data/src/core/ext/xds/xds_bootstrap_grpc.cc +370 -0
  79. data/src/core/ext/xds/xds_bootstrap_grpc.h +169 -0
  80. data/src/core/ext/xds/xds_client.cc +219 -145
  81. data/src/core/ext/xds/xds_client.h +19 -17
  82. data/src/core/ext/xds/xds_client_grpc.cc +18 -80
  83. data/src/core/ext/xds/xds_client_grpc.h +2 -25
  84. data/src/core/ext/xds/xds_client_stats.cc +4 -4
  85. data/src/core/ext/xds/xds_cluster.cc +87 -79
  86. data/src/core/ext/xds/xds_cluster.h +5 -5
  87. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +3 -1
  88. data/src/core/ext/xds/xds_common_types.cc +13 -5
  89. data/src/core/ext/xds/xds_endpoint.cc +8 -6
  90. data/src/core/ext/xds/xds_endpoint.h +3 -4
  91. data/src/core/ext/xds/xds_lb_policy_registry.cc +4 -2
  92. data/src/core/ext/xds/xds_listener.cc +25 -20
  93. data/src/core/ext/xds/xds_listener.h +3 -4
  94. data/src/core/ext/xds/xds_resource_type.h +11 -8
  95. data/src/core/ext/xds/xds_route_config.cc +15 -16
  96. data/src/core/ext/xds/xds_route_config.h +3 -3
  97. data/src/core/ext/xds/xds_server_config_fetcher.cc +7 -5
  98. data/src/core/ext/xds/xds_transport_grpc.cc +15 -7
  99. data/src/core/lib/backoff/backoff.cc +2 -4
  100. data/src/core/lib/channel/call_finalization.h +1 -3
  101. data/src/core/lib/channel/channel_args.h +114 -14
  102. data/src/core/lib/channel/channel_trace.cc +3 -4
  103. data/src/core/lib/channel/promise_based_filter.cc +18 -19
  104. data/src/core/lib/channel/status_util.cc +27 -0
  105. data/src/core/lib/channel/status_util.h +10 -0
  106. data/src/core/lib/config/core_configuration.cc +5 -1
  107. data/src/core/lib/config/core_configuration.h +33 -0
  108. data/src/core/lib/debug/stats.cc +26 -30
  109. data/src/core/lib/debug/stats.h +2 -12
  110. data/src/core/lib/debug/stats_data.cc +118 -614
  111. data/src/core/lib/debug/stats_data.h +67 -465
  112. data/src/core/lib/debug/trace.cc +0 -2
  113. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +12 -20
  114. data/src/core/lib/event_engine/channel_args_endpoint_config.h +13 -7
  115. data/src/core/lib/event_engine/forkable.cc +19 -16
  116. data/src/core/lib/event_engine/poller.h +14 -12
  117. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +53 -32
  118. data/src/core/lib/event_engine/posix_engine/timer_manager.h +23 -1
  119. data/src/core/lib/event_engine/thread_pool.cc +131 -94
  120. data/src/core/lib/event_engine/thread_pool.h +56 -23
  121. data/src/core/lib/event_engine/time_util.cc +30 -0
  122. data/src/core/lib/event_engine/time_util.h +32 -0
  123. data/src/core/lib/event_engine/utils.cc +0 -5
  124. data/src/core/lib/event_engine/utils.h +0 -4
  125. data/src/core/lib/event_engine/windows/iocp.cc +13 -7
  126. data/src/core/lib/event_engine/windows/iocp.h +2 -1
  127. data/src/core/lib/event_engine/windows/win_socket.cc +1 -1
  128. data/src/core/lib/experiments/config.cc +146 -0
  129. data/src/core/lib/experiments/config.h +43 -0
  130. data/src/core/lib/experiments/experiments.cc +75 -0
  131. data/src/core/lib/experiments/experiments.h +56 -0
  132. data/src/core/lib/gpr/alloc.cc +1 -9
  133. data/src/core/lib/gpr/log_windows.cc +0 -1
  134. data/src/core/lib/gpr/string_util_windows.cc +3 -30
  135. data/src/core/lib/gpr/sync_abseil.cc +0 -14
  136. data/src/core/lib/gpr/sync_posix.cc +0 -14
  137. data/src/core/lib/gpr/time_posix.cc +0 -6
  138. data/src/core/lib/gpr/time_precise.h +1 -1
  139. data/src/core/lib/gpr/tmpfile_windows.cc +5 -7
  140. data/src/core/lib/gpr/useful.h +11 -0
  141. data/src/core/lib/{gpr → gprpp}/env.h +25 -12
  142. data/src/core/lib/{gpr → gprpp}/env_linux.cc +20 -15
  143. data/src/core/lib/{gpr → gprpp}/env_posix.cc +11 -10
  144. data/src/core/lib/gprpp/env_windows.cc +56 -0
  145. data/src/core/lib/gprpp/fork.cc +14 -22
  146. data/src/core/lib/gprpp/fork.h +0 -8
  147. data/src/core/lib/gprpp/global_config_env.cc +7 -6
  148. data/src/core/lib/gprpp/notification.h +67 -0
  149. data/src/core/lib/gprpp/packed_table.h +40 -0
  150. data/src/core/lib/gprpp/ref_counted_ptr.h +20 -33
  151. data/src/core/lib/gprpp/sorted_pack.h +98 -0
  152. data/src/core/lib/gprpp/status_helper.h +6 -0
  153. data/src/core/lib/gprpp/table.h +9 -1
  154. data/src/core/lib/gprpp/tchar.cc +49 -0
  155. data/src/core/lib/gprpp/tchar.h +33 -0
  156. data/src/core/lib/gprpp/time.cc +21 -0
  157. data/src/core/lib/gprpp/time.h +55 -0
  158. data/src/core/lib/gprpp/validation_errors.cc +61 -0
  159. data/src/core/lib/gprpp/validation_errors.h +110 -0
  160. data/src/core/{ext/filters/client_channel → lib/handshaker}/proxy_mapper.h +3 -3
  161. data/src/core/{ext/filters/client_channel → lib/handshaker}/proxy_mapper_registry.cc +14 -36
  162. data/src/core/lib/handshaker/proxy_mapper_registry.h +75 -0
  163. data/src/core/lib/iomgr/call_combiner.cc +0 -8
  164. data/src/core/lib/iomgr/closure.h +0 -1
  165. data/src/core/lib/iomgr/endpoint_pair_posix.cc +14 -10
  166. data/src/core/lib/iomgr/endpoint_pair_windows.cc +2 -2
  167. data/src/core/lib/iomgr/ev_epoll1_linux.cc +1 -38
  168. data/src/core/lib/iomgr/ev_poll_posix.cc +2 -17
  169. data/src/core/lib/iomgr/exec_ctx.cc +0 -10
  170. data/src/core/lib/iomgr/exec_ctx.h +7 -31
  171. data/src/core/lib/iomgr/iocp_windows.cc +1 -2
  172. data/src/core/lib/iomgr/iomgr.cc +6 -8
  173. data/src/core/lib/iomgr/iomgr_fwd.h +1 -0
  174. data/src/core/lib/iomgr/pollset.h +1 -1
  175. data/src/core/lib/iomgr/pollset_set.h +0 -1
  176. data/src/core/lib/iomgr/resolve_address.h +1 -0
  177. data/src/core/lib/iomgr/resolve_address_impl.h +1 -0
  178. data/src/core/lib/iomgr/resolve_address_posix.cc +5 -0
  179. data/src/core/lib/iomgr/resolve_address_windows.cc +5 -0
  180. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +2 -1
  181. data/src/core/lib/iomgr/socket_utils_common_posix.cc +12 -34
  182. data/src/core/lib/iomgr/socket_utils_posix.cc +83 -1
  183. data/src/core/lib/iomgr/socket_utils_posix.h +98 -6
  184. data/src/core/lib/iomgr/tcp_client.cc +6 -7
  185. data/src/core/lib/iomgr/tcp_client.h +11 -11
  186. data/src/core/lib/iomgr/tcp_client_cfstream.cc +6 -6
  187. data/src/core/lib/iomgr/tcp_client_posix.cc +33 -29
  188. data/src/core/lib/iomgr/tcp_client_posix.h +12 -9
  189. data/src/core/lib/iomgr/tcp_client_windows.cc +6 -6
  190. data/src/core/lib/iomgr/tcp_posix.cc +131 -114
  191. data/src/core/lib/iomgr/tcp_posix.h +3 -1
  192. data/src/core/lib/iomgr/tcp_server.cc +5 -4
  193. data/src/core/lib/iomgr/tcp_server.h +9 -6
  194. data/src/core/lib/iomgr/tcp_server_posix.cc +17 -28
  195. data/src/core/lib/iomgr/tcp_server_utils_posix.h +2 -2
  196. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +3 -3
  197. data/src/core/lib/iomgr/tcp_server_windows.cc +6 -7
  198. data/src/core/lib/iomgr/tcp_windows.cc +0 -1
  199. data/src/core/lib/iomgr/tcp_windows.h +0 -1
  200. data/src/core/lib/iomgr/timer_generic.cc +4 -4
  201. data/src/core/lib/iomgr/timer_manager.cc +1 -2
  202. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +0 -2
  203. data/src/core/lib/json/json_object_loader.cc +21 -52
  204. data/src/core/lib/json/json_object_loader.h +56 -76
  205. data/src/core/lib/json/json_util.cc +2 -1
  206. data/src/core/lib/load_balancing/lb_policy.h +5 -5
  207. data/src/core/lib/load_balancing/lb_policy_registry.cc +29 -55
  208. data/src/core/lib/load_balancing/lb_policy_registry.h +23 -11
  209. data/src/core/lib/promise/activity.h +2 -3
  210. data/src/core/lib/promise/context.h +1 -1
  211. data/src/core/lib/promise/sleep.cc +16 -4
  212. data/src/core/lib/promise/sleep.h +8 -2
  213. data/src/core/lib/resolver/resolver.h +13 -3
  214. data/src/core/lib/resource_quota/api.cc +9 -0
  215. data/src/core/lib/resource_quota/api.h +6 -0
  216. data/src/core/lib/resource_quota/arena.cc +1 -3
  217. data/src/core/lib/resource_quota/memory_quota.cc +8 -24
  218. data/src/core/lib/resource_quota/memory_quota.h +6 -19
  219. data/src/core/lib/resource_quota/periodic_update.cc +2 -3
  220. data/src/core/{ext/xds → lib/security/certificate_provider}/certificate_provider_factory.h +3 -3
  221. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +60 -0
  222. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +70 -0
  223. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +1 -0
  224. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +15 -16
  225. data/src/core/lib/security/credentials/external/external_account_credentials.cc +2 -1
  226. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +5 -8
  227. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +6 -6
  228. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +3 -2
  229. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +1 -1
  230. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +1 -2
  231. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +4 -3
  232. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +4 -2
  233. data/src/core/lib/security/credentials/tls/tls_utils.cc +3 -1
  234. data/src/core/lib/security/transport/client_auth_filter.cc +12 -1
  235. data/src/core/lib/security/transport/secure_endpoint.cc +0 -4
  236. data/src/core/lib/surface/call.cc +1 -11
  237. data/src/core/lib/surface/channel.cc +3 -2
  238. data/src/core/lib/surface/completion_queue.cc +16 -28
  239. data/src/core/lib/surface/completion_queue.h +1 -1
  240. data/src/core/lib/surface/completion_queue_factory.cc +5 -0
  241. data/src/core/lib/surface/init.cc +16 -11
  242. data/src/core/lib/surface/init_internally.cc +24 -0
  243. data/src/core/lib/surface/init_internally.h +28 -0
  244. data/src/core/lib/surface/server.cc +1 -7
  245. data/src/core/lib/surface/server.h +4 -6
  246. data/src/core/lib/surface/version.cc +2 -2
  247. data/src/core/lib/transport/bdp_estimator.cc +1 -3
  248. data/src/core/lib/transport/metadata_batch.cc +2 -3
  249. data/src/core/lib/transport/metadata_batch.h +9 -7
  250. data/src/core/lib/transport/parsed_metadata.h +4 -2
  251. data/src/core/lib/transport/status_conversion.cc +1 -3
  252. data/src/core/lib/transport/tcp_connect_handshaker.cc +9 -5
  253. data/src/core/lib/transport/transport.h +0 -1
  254. data/src/core/lib/transport/transport_impl.h +0 -1
  255. data/src/core/plugin_registry/grpc_plugin_registry.cc +23 -46
  256. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +13 -25
  257. data/src/ruby/ext/grpc/extconf.rb +1 -1
  258. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  259. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  260. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  261. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  262. data/src/ruby/lib/grpc/grpc_c.so +0 -0
  263. data/src/ruby/lib/grpc/version.rb +1 -1
  264. data/src/ruby/spec/channel_spec.rb +5 -0
  265. data/src/ruby/spec/generic/server_interceptors_spec.rb +1 -1
  266. data/src/ruby/spec/user_agent_spec.rb +1 -1
  267. metadata +32 -19
  268. data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +0 -56
  269. data/src/core/ext/xds/certificate_provider_registry.cc +0 -103
  270. data/src/core/ext/xds/certificate_provider_registry.h +0 -59
  271. data/src/core/lib/event_engine/promise.h +0 -78
  272. data/src/core/lib/gpr/env_windows.cc +0 -74
  273. data/src/core/lib/gpr/string_windows.h +0 -32
  274. data/src/core/lib/profiling/basic_timers.cc +0 -295
  275. data/src/core/lib/profiling/stap_timers.cc +0 -50
  276. data/src/core/lib/profiling/timers.h +0 -94
  277. data/src/ruby/lib/grpc/2.5/grpc_c.so +0 -0
@@ -37,6 +37,7 @@
37
37
 
38
38
  #include "src/core/ext/filters/client_channel/lb_policy/subchannel_list.h"
39
39
  #include "src/core/lib/channel/channel_args.h"
40
+ #include "src/core/lib/config/core_configuration.h"
40
41
  #include "src/core/lib/debug/trace.h"
41
42
  #include "src/core/lib/gprpp/debug_location.h"
42
43
  #include "src/core/lib/gprpp/orphanable.h"
@@ -67,7 +68,7 @@ class RoundRobin : public LoadBalancingPolicy {
67
68
 
68
69
  absl::string_view name() const override { return kRoundRobin; }
69
70
 
70
- void UpdateLocked(UpdateArgs args) override;
71
+ absl::Status UpdateLocked(UpdateArgs args) override;
71
72
  void ResetBackoffLocked() override;
72
73
 
73
74
  private:
@@ -182,12 +183,12 @@ class RoundRobin : public LoadBalancingPolicy {
182
183
  void ShutdownLocked() override;
183
184
 
184
185
  // List of subchannels.
185
- OrphanablePtr<RoundRobinSubchannelList> subchannel_list_;
186
+ RefCountedPtr<RoundRobinSubchannelList> subchannel_list_;
186
187
  // Latest pending subchannel list.
187
188
  // When we get an updated address list, we create a new subchannel list
188
189
  // for it here, and we wait to swap it into subchannel_list_ until the new
189
190
  // list becomes READY.
190
- OrphanablePtr<RoundRobinSubchannelList> latest_pending_subchannel_list_;
191
+ RefCountedPtr<RoundRobinSubchannelList> latest_pending_subchannel_list_;
191
192
 
192
193
  bool shutdown_ = false;
193
194
  };
@@ -265,7 +266,7 @@ void RoundRobin::ResetBackoffLocked() {
265
266
  }
266
267
  }
267
268
 
268
- void RoundRobin::UpdateLocked(UpdateArgs args) {
269
+ absl::Status RoundRobin::UpdateLocked(UpdateArgs args) {
269
270
  ServerAddressList addresses;
270
271
  if (args.addresses.ok()) {
271
272
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_round_robin_trace)) {
@@ -278,9 +279,9 @@ void RoundRobin::UpdateLocked(UpdateArgs args) {
278
279
  gpr_log(GPR_INFO, "[RR %p] received update with address error: %s", this,
279
280
  args.addresses.status().ToString().c_str());
280
281
  }
281
- // If we already have a subchannel list, then ignore the resolver
282
- // failure and keep using the existing list.
283
- if (subchannel_list_ != nullptr) return;
282
+ // If we already have a subchannel list, then keep using the existing
283
+ // list, but still report back that the update was not accepted.
284
+ if (subchannel_list_ != nullptr) return args.addresses.status();
284
285
  }
285
286
  // Create new subchannel list, replacing the previous pending list, if any.
286
287
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_round_robin_trace) &&
@@ -288,7 +289,7 @@ void RoundRobin::UpdateLocked(UpdateArgs args) {
288
289
  gpr_log(GPR_INFO, "[RR %p] replacing previous pending subchannel list %p",
289
290
  this, latest_pending_subchannel_list_.get());
290
291
  }
291
- latest_pending_subchannel_list_ = MakeOrphanable<RoundRobinSubchannelList>(
292
+ latest_pending_subchannel_list_ = MakeRefCounted<RoundRobinSubchannelList>(
292
293
  this, std::move(addresses), args.args);
293
294
  latest_pending_subchannel_list_->StartWatchingLocked();
294
295
  // If the new list is empty, immediately promote it to
@@ -307,15 +308,17 @@ void RoundRobin::UpdateLocked(UpdateArgs args) {
307
308
  channel_control_helper()->UpdateState(
308
309
  GRPC_CHANNEL_TRANSIENT_FAILURE, status,
309
310
  absl::make_unique<TransientFailurePicker>(status));
311
+ return status;
310
312
  }
311
313
  // Otherwise, if this is the initial update, immediately promote it to
312
314
  // subchannel_list_ and report CONNECTING.
313
- else if (subchannel_list_.get() == nullptr) {
315
+ if (subchannel_list_.get() == nullptr) {
314
316
  subchannel_list_ = std::move(latest_pending_subchannel_list_);
315
317
  channel_control_helper()->UpdateState(
316
318
  GRPC_CHANNEL_CONNECTING, absl::Status(),
317
319
  absl::make_unique<QueuePicker>(Ref(DEBUG_LOCATION, "QueuePicker")));
318
320
  }
321
+ return absl::OkStatus();
319
322
  }
320
323
 
321
324
  //
@@ -520,12 +523,9 @@ class RoundRobinFactory : public LoadBalancingPolicyFactory {
520
523
 
521
524
  } // namespace
522
525
 
523
- } // namespace grpc_core
524
-
525
- void grpc_lb_policy_round_robin_init() {
526
- grpc_core::LoadBalancingPolicyRegistry::Builder::
527
- RegisterLoadBalancingPolicyFactory(
528
- absl::make_unique<grpc_core::RoundRobinFactory>());
526
+ void RegisterRoundRobinLbPolicy(CoreConfiguration::Builder* builder) {
527
+ builder->lb_policy_registry()->RegisterLoadBalancingPolicyFactory(
528
+ absl::make_unique<RoundRobinFactory>());
529
529
  }
530
530
 
531
- void grpc_lb_policy_round_robin_shutdown() {}
531
+ } // namespace grpc_core
@@ -35,8 +35,8 @@
35
35
 
36
36
  #include "src/core/lib/channel/channel_args.h"
37
37
  #include "src/core/lib/gprpp/debug_location.h"
38
+ #include "src/core/lib/gprpp/dual_ref_counted.h"
38
39
  #include "src/core/lib/gprpp/manual_constructor.h"
39
- #include "src/core/lib/gprpp/orphanable.h"
40
40
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
41
41
  #include "src/core/lib/iomgr/iomgr_fwd.h"
42
42
  #include "src/core/lib/load_balancing/lb_policy.h"
@@ -131,7 +131,7 @@ class SubchannelData {
131
131
  public:
132
132
  Watcher(
133
133
  SubchannelData<SubchannelListType, SubchannelDataType>* subchannel_data,
134
- RefCountedPtr<SubchannelListType> subchannel_list)
134
+ WeakRefCountedPtr<SubchannelListType> subchannel_list)
135
135
  : subchannel_data_(subchannel_data),
136
136
  subchannel_list_(std::move(subchannel_list)) {}
137
137
 
@@ -148,7 +148,7 @@ class SubchannelData {
148
148
 
149
149
  private:
150
150
  SubchannelData<SubchannelListType, SubchannelDataType>* subchannel_data_;
151
- RefCountedPtr<SubchannelListType> subchannel_list_;
151
+ WeakRefCountedPtr<SubchannelListType> subchannel_list_;
152
152
  };
153
153
 
154
154
  // Starts watching the connectivity state of the subchannel.
@@ -176,7 +176,7 @@ class SubchannelData {
176
176
 
177
177
  // A list of subchannels.
178
178
  template <typename SubchannelListType, typename SubchannelDataType>
179
- class SubchannelList : public InternallyRefCounted<SubchannelListType> {
179
+ class SubchannelList : public DualRefCounted<SubchannelListType> {
180
180
  public:
181
181
  // Starts watching the connectivity state of all subchannels.
182
182
  // Must be called immediately after instantiation.
@@ -200,10 +200,7 @@ class SubchannelList : public InternallyRefCounted<SubchannelListType> {
200
200
  // Resets connection backoff of all subchannels.
201
201
  void ResetBackoffLocked();
202
202
 
203
- void Orphan() override {
204
- ShutdownLocked();
205
- InternallyRefCounted<SubchannelListType>::Unref(DEBUG_LOCATION, "shutdown");
206
- }
203
+ void Orphan() override;
207
204
 
208
205
  protected:
209
206
  SubchannelList(LoadBalancingPolicy* policy, const char* tracer,
@@ -213,8 +210,6 @@ class SubchannelList : public InternallyRefCounted<SubchannelListType> {
213
210
 
214
211
  virtual ~SubchannelList();
215
212
 
216
- virtual void ShutdownLocked();
217
-
218
213
  private:
219
214
  // For accessing Ref() and Unref().
220
215
  friend class SubchannelData<SubchannelListType, SubchannelDataType>;
@@ -327,7 +322,7 @@ void SubchannelData<SubchannelListType,
327
322
  }
328
323
  GPR_ASSERT(pending_watcher_ == nullptr);
329
324
  pending_watcher_ =
330
- new Watcher(this, subchannel_list()->Ref(DEBUG_LOCATION, "Watcher"));
325
+ new Watcher(this, subchannel_list()->WeakRef(DEBUG_LOCATION, "Watcher"));
331
326
  subchannel_->WatchConnectivityState(
332
327
  std::unique_ptr<SubchannelInterface::ConnectivityStateWatcherInterface>(
333
328
  pending_watcher_));
@@ -365,7 +360,7 @@ SubchannelList<SubchannelListType, SubchannelDataType>::SubchannelList(
365
360
  LoadBalancingPolicy* policy, const char* tracer,
366
361
  ServerAddressList addresses,
367
362
  LoadBalancingPolicy::ChannelControlHelper* helper, const ChannelArgs& args)
368
- : InternallyRefCounted<SubchannelListType>(tracer),
363
+ : DualRefCounted<SubchannelListType>(tracer),
369
364
  policy_(policy),
370
365
  tracer_(tracer) {
371
366
  if (GPR_UNLIKELY(tracer_ != nullptr)) {
@@ -419,7 +414,7 @@ void SubchannelList<SubchannelListType,
419
414
  }
420
415
 
421
416
  template <typename SubchannelListType, typename SubchannelDataType>
422
- void SubchannelList<SubchannelListType, SubchannelDataType>::ShutdownLocked() {
417
+ void SubchannelList<SubchannelListType, SubchannelDataType>::Orphan() {
423
418
  if (GPR_UNLIKELY(tracer_ != nullptr)) {
424
419
  gpr_log(GPR_INFO, "[%s %p] Shutting down subchannel_list %p", tracer_,
425
420
  policy_, this);
@@ -41,17 +41,21 @@
41
41
  #include "src/core/ext/filters/client_channel/lb_policy/address_filtering.h"
42
42
  #include "src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h"
43
43
  #include "src/core/lib/channel/channel_args.h"
44
+ #include "src/core/lib/config/core_configuration.h"
44
45
  #include "src/core/lib/debug/trace.h"
45
46
  #include "src/core/lib/event_engine/default_event_engine.h"
46
- #include "src/core/lib/gpr/string.h"
47
47
  #include "src/core/lib/gprpp/debug_location.h"
48
48
  #include "src/core/lib/gprpp/orphanable.h"
49
49
  #include "src/core/lib/gprpp/ref_counted.h"
50
50
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
51
51
  #include "src/core/lib/gprpp/time.h"
52
+ #include "src/core/lib/gprpp/validation_errors.h"
52
53
  #include "src/core/lib/gprpp/work_serializer.h"
54
+ #include "src/core/lib/iomgr/exec_ctx.h"
53
55
  #include "src/core/lib/iomgr/pollset_set.h"
54
56
  #include "src/core/lib/json/json.h"
57
+ #include "src/core/lib/json/json_args.h"
58
+ #include "src/core/lib/json/json_object_loader.h"
55
59
  #include "src/core/lib/load_balancing/lb_policy.h"
56
60
  #include "src/core/lib/load_balancing/lb_policy_factory.h"
57
61
  #include "src/core/lib/load_balancing/lb_policy_registry.h"
@@ -82,17 +86,28 @@ class WeightedTargetLbConfig : public LoadBalancingPolicy::Config {
82
86
  struct ChildConfig {
83
87
  uint32_t weight;
84
88
  RefCountedPtr<LoadBalancingPolicy::Config> config;
89
+
90
+ static const JsonLoaderInterface* JsonLoader(const JsonArgs&);
91
+ void JsonPostLoad(const Json& json, const JsonArgs&,
92
+ ValidationErrors* errors);
85
93
  };
86
94
 
87
95
  using TargetMap = std::map<std::string, ChildConfig>;
88
96
 
89
- explicit WeightedTargetLbConfig(TargetMap target_map)
90
- : target_map_(std::move(target_map)) {}
97
+ WeightedTargetLbConfig() = default;
98
+
99
+ WeightedTargetLbConfig(const WeightedTargetLbConfig&) = delete;
100
+ WeightedTargetLbConfig& operator=(const WeightedTargetLbConfig&) = delete;
101
+
102
+ WeightedTargetLbConfig(WeightedTargetLbConfig&& other) = delete;
103
+ WeightedTargetLbConfig& operator=(WeightedTargetLbConfig&& other) = delete;
91
104
 
92
105
  absl::string_view name() const override { return kWeightedTarget; }
93
106
 
94
107
  const TargetMap& target_map() const { return target_map_; }
95
108
 
109
+ static const JsonLoaderInterface* JsonLoader(const JsonArgs&);
110
+
96
111
  private:
97
112
  TargetMap target_map_;
98
113
  };
@@ -104,7 +119,7 @@ class WeightedTargetLb : public LoadBalancingPolicy {
104
119
 
105
120
  absl::string_view name() const override { return kWeightedTarget; }
106
121
 
107
- void UpdateLocked(UpdateArgs args) override;
122
+ absl::Status UpdateLocked(UpdateArgs args) override;
108
123
  void ResetBackoffLocked() override;
109
124
 
110
125
  private:
@@ -148,10 +163,10 @@ class WeightedTargetLb : public LoadBalancingPolicy {
148
163
 
149
164
  void Orphan() override;
150
165
 
151
- void UpdateLocked(const WeightedTargetLbConfig::ChildConfig& config,
152
- absl::StatusOr<ServerAddressList> addresses,
153
- const std::string& resolution_note,
154
- const ChannelArgs& args);
166
+ absl::Status UpdateLocked(const WeightedTargetLbConfig::ChildConfig& config,
167
+ absl::StatusOr<ServerAddressList> addresses,
168
+ const std::string& resolution_note,
169
+ const ChannelArgs& args);
155
170
  void ResetBackoffLocked();
156
171
  void DeactivateLocked();
157
172
 
@@ -300,8 +315,8 @@ void WeightedTargetLb::ResetBackoffLocked() {
300
315
  for (auto& p : targets_) p.second->ResetBackoffLocked();
301
316
  }
302
317
 
303
- void WeightedTargetLb::UpdateLocked(UpdateArgs args) {
304
- if (shutting_down_) return;
318
+ absl::Status WeightedTargetLb::UpdateLocked(UpdateArgs args) {
319
+ if (shutting_down_) return absl::OkStatus();
305
320
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_weighted_target_trace)) {
306
321
  gpr_log(GPR_INFO, "[weighted_target_lb %p] Received update", this);
307
322
  }
@@ -319,6 +334,7 @@ void WeightedTargetLb::UpdateLocked(UpdateArgs args) {
319
334
  // Update all children.
320
335
  absl::StatusOr<HierarchicalAddressMap> address_map =
321
336
  MakeHierarchicalAddressMap(args.addresses);
337
+ std::vector<std::string> errors;
322
338
  for (const auto& p : config_->target_map()) {
323
339
  const std::string& name = p.first;
324
340
  const WeightedTargetLbConfig::ChildConfig& config = p.second;
@@ -334,8 +350,12 @@ void WeightedTargetLb::UpdateLocked(UpdateArgs args) {
334
350
  } else {
335
351
  addresses = address_map.status();
336
352
  }
337
- target->UpdateLocked(config, std::move(addresses), args.resolution_note,
338
- args.args);
353
+ absl::Status status = target->UpdateLocked(config, std::move(addresses),
354
+ args.resolution_note, args.args);
355
+ if (!status.ok()) {
356
+ errors.emplace_back(
357
+ absl::StrCat("child ", name, ": ", status.ToString()));
358
+ }
339
359
  }
340
360
  update_in_progress_ = false;
341
361
  if (config_->target_map().empty()) {
@@ -344,9 +364,15 @@ void WeightedTargetLb::UpdateLocked(UpdateArgs args) {
344
364
  channel_control_helper()->UpdateState(
345
365
  GRPC_CHANNEL_TRANSIENT_FAILURE, status,
346
366
  absl::make_unique<TransientFailurePicker>(status));
347
- return;
367
+ return absl::OkStatus();
348
368
  }
349
369
  UpdateStateLocked();
370
+ // Return status.
371
+ if (!errors.empty()) {
372
+ return absl::UnavailableError(absl::StrCat(
373
+ "errors from children: [", absl::StrJoin(errors, "; "), "]"));
374
+ }
375
+ return absl::OkStatus();
350
376
  }
351
377
 
352
378
  void WeightedTargetLb::UpdateStateLocked() {
@@ -456,6 +482,8 @@ WeightedTargetLb::WeightedChild::DelayedRemovalTimer::DelayedRemovalTimer(
456
482
  : weighted_child_(std::move(weighted_child)) {
457
483
  timer_handle_ = GetDefaultEventEngine()->RunAfter(
458
484
  kChildRetentionInterval, [self = Ref()]() mutable {
485
+ ApplicationCallbackExecCtx app_exec_ctx;
486
+ ExecCtx exec_ctx;
459
487
  self->weighted_child_->weighted_target_policy_->work_serializer()->Run(
460
488
  [self = std::move(self)] { self->OnTimerLocked(); },
461
489
  DEBUG_LOCATION);
@@ -552,11 +580,11 @@ WeightedTargetLb::WeightedChild::CreateChildPolicyLocked(
552
580
  return lb_policy;
553
581
  }
554
582
 
555
- void WeightedTargetLb::WeightedChild::UpdateLocked(
583
+ absl::Status WeightedTargetLb::WeightedChild::UpdateLocked(
556
584
  const WeightedTargetLbConfig::ChildConfig& config,
557
585
  absl::StatusOr<ServerAddressList> addresses,
558
586
  const std::string& resolution_note, const ChannelArgs& args) {
559
- if (weighted_target_policy_->shutting_down_) return;
587
+ if (weighted_target_policy_->shutting_down_) return absl::OkStatus();
560
588
  // Update child weight.
561
589
  weight_ = config.weight;
562
590
  // Reactivate if needed.
@@ -586,7 +614,7 @@ void WeightedTargetLb::WeightedChild::UpdateLocked(
586
614
  weighted_target_policy_.get(), this, name_.c_str(),
587
615
  child_policy_.get());
588
616
  }
589
- child_policy_->UpdateLocked(std::move(update_args));
617
+ return child_policy_->UpdateLocked(std::move(update_args));
590
618
  }
591
619
 
592
620
  void WeightedTargetLb::WeightedChild::ResetBackoffLocked() {
@@ -676,6 +704,43 @@ void WeightedTargetLb::WeightedChild::Helper::AddTraceEvent(
676
704
  // factory
677
705
  //
678
706
 
707
+ const JsonLoaderInterface* WeightedTargetLbConfig::ChildConfig::JsonLoader(
708
+ const JsonArgs&) {
709
+ static const auto* loader =
710
+ JsonObjectLoader<ChildConfig>()
711
+ // Note: The config field requires custom parsing, so it's
712
+ // handled in JsonPostLoad() instead.
713
+ .Field("weight", &ChildConfig::weight)
714
+ .Finish();
715
+ return loader;
716
+ }
717
+
718
+ void WeightedTargetLbConfig::ChildConfig::JsonPostLoad(
719
+ const Json& json, const JsonArgs&, ValidationErrors* errors) {
720
+ ValidationErrors::ScopedField field(errors, ".childPolicy");
721
+ auto it = json.object_value().find("childPolicy");
722
+ if (it == json.object_value().end()) {
723
+ errors->AddError("field not present");
724
+ return;
725
+ }
726
+ auto lb_config =
727
+ CoreConfiguration::Get().lb_policy_registry().ParseLoadBalancingConfig(
728
+ it->second);
729
+ if (!lb_config.ok()) {
730
+ errors->AddError(lb_config.status().message());
731
+ return;
732
+ }
733
+ config = std::move(*lb_config);
734
+ }
735
+
736
+ const JsonLoaderInterface* WeightedTargetLbConfig::JsonLoader(const JsonArgs&) {
737
+ static const auto* loader =
738
+ JsonObjectLoader<WeightedTargetLbConfig>()
739
+ .Field("targets", &WeightedTargetLbConfig::target_map_)
740
+ .Finish();
741
+ return loader;
742
+ }
743
+
679
744
  class WeightedTargetLbFactory : public LoadBalancingPolicyFactory {
680
745
  public:
681
746
  OrphanablePtr<LoadBalancingPolicy> CreateLoadBalancingPolicy(
@@ -695,90 +760,16 @@ class WeightedTargetLbFactory : public LoadBalancingPolicyFactory {
695
760
  "configuration. Please use loadBalancingConfig field of service "
696
761
  "config instead.");
697
762
  }
698
- std::vector<std::string> errors;
699
- // Weight map.
700
- WeightedTargetLbConfig::TargetMap target_map;
701
- auto it = json.object_value().find("targets");
702
- if (it == json.object_value().end()) {
703
- errors.emplace_back("field:targets error:required field not present");
704
- } else if (it->second.type() != Json::Type::OBJECT) {
705
- errors.emplace_back("field:targets error:type should be object");
706
- } else {
707
- for (const auto& p : it->second.object_value()) {
708
- auto config = ParseChildConfig(p.second);
709
- if (!config.ok()) {
710
- errors.emplace_back(config.status().message());
711
- } else {
712
- target_map[p.first] = std::move(*config);
713
- }
714
- }
715
- }
716
- if (!errors.empty()) {
717
- return absl::InvalidArgumentError(
718
- absl::StrCat("weighted_target_experimental LB policy config: [",
719
- absl::StrJoin(errors, "; "), "]"));
720
- }
721
- return MakeRefCounted<WeightedTargetLbConfig>(std::move(target_map));
722
- }
723
-
724
- private:
725
- static absl::StatusOr<WeightedTargetLbConfig::ChildConfig> ParseChildConfig(
726
- const Json& json) {
727
- if (json.type() != Json::Type::OBJECT) {
728
- return absl::InvalidArgumentError("value should be of type object");
729
- }
730
- WeightedTargetLbConfig::ChildConfig child_config;
731
- std::vector<std::string> errors;
732
- // Weight.
733
- auto it = json.object_value().find("weight");
734
- if (it == json.object_value().end()) {
735
- errors.emplace_back("required field \"weight\" not specified");
736
- } else if (it->second.type() != Json::Type::NUMBER) {
737
- errors.emplace_back("field:weight error:must be of type number");
738
- } else {
739
- int weight = gpr_parse_nonnegative_int(it->second.string_value().c_str());
740
- if (weight == -1) {
741
- errors.emplace_back("field:weight error:unparseable value");
742
- } else if (weight == 0) {
743
- errors.emplace_back(
744
- "field:weight error:value must be greater than zero");
745
- } else {
746
- child_config.weight = weight;
747
- }
748
- }
749
- // Child policy.
750
- it = json.object_value().find("childPolicy");
751
- if (it != json.object_value().end()) {
752
- auto config =
753
- LoadBalancingPolicyRegistry::ParseLoadBalancingConfig(it->second);
754
- if (!config.ok()) {
755
- errors.emplace_back(
756
- absl::StrCat("field:childPolicy: ", config.status().message()));
757
- } else {
758
- child_config.config = std::move(*config);
759
- }
760
- }
761
- // Return result.
762
- if (!errors.empty()) {
763
- return absl::InvalidArgumentError(absl::StrCat(
764
- "errors parsing target config: [", absl::StrJoin(errors, "; "), "]"));
765
- }
766
- return child_config;
763
+ return LoadRefCountedFromJson<WeightedTargetLbConfig>(
764
+ json, JsonArgs(), "errors validating weighted_target LB policy config");
767
765
  }
768
766
  };
769
767
 
770
768
  } // namespace
771
769
 
772
- } // namespace grpc_core
773
-
774
- //
775
- // Plugin registration
776
- //
777
-
778
- void grpc_lb_policy_weighted_target_init() {
779
- grpc_core::LoadBalancingPolicyRegistry::Builder::
780
- RegisterLoadBalancingPolicyFactory(
781
- absl::make_unique<grpc_core::WeightedTargetLbFactory>());
770
+ void RegisterWeightedTargetLbPolicy(CoreConfiguration::Builder* builder) {
771
+ builder->lb_policy_registry()->RegisterLoadBalancingPolicyFactory(
772
+ absl::make_unique<WeightedTargetLbFactory>());
782
773
  }
783
774
 
784
- void grpc_lb_policy_weighted_target_shutdown() {}
775
+ } // namespace grpc_core
@@ -28,7 +28,6 @@
28
28
  #include "absl/status/status.h"
29
29
  #include "absl/status/statusor.h"
30
30
  #include "absl/strings/str_cat.h"
31
- #include "absl/strings/str_join.h"
32
31
  #include "absl/strings/string_view.h"
33
32
  #include "absl/types/optional.h"
34
33
 
@@ -39,7 +38,7 @@
39
38
 
40
39
  #include "src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h"
41
40
  #include "src/core/ext/xds/certificate_provider_store.h"
42
- #include "src/core/ext/xds/xds_bootstrap.h"
41
+ #include "src/core/ext/xds/xds_bootstrap_grpc.h"
43
42
  #include "src/core/ext/xds/xds_certificate_provider.h"
44
43
  #include "src/core/ext/xds/xds_client.h"
45
44
  #include "src/core/ext/xds/xds_client_grpc.h"
@@ -47,6 +46,7 @@
47
46
  #include "src/core/ext/xds/xds_common_types.h"
48
47
  #include "src/core/ext/xds/xds_resource_type_impl.h"
49
48
  #include "src/core/lib/channel/channel_args.h"
49
+ #include "src/core/lib/config/core_configuration.h"
50
50
  #include "src/core/lib/debug/trace.h"
51
51
  #include "src/core/lib/gprpp/debug_location.h"
52
52
  #include "src/core/lib/gprpp/orphanable.h"
@@ -57,6 +57,8 @@
57
57
  #include "src/core/lib/iomgr/error.h"
58
58
  #include "src/core/lib/iomgr/pollset_set.h"
59
59
  #include "src/core/lib/json/json.h"
60
+ #include "src/core/lib/json/json_args.h"
61
+ #include "src/core/lib/json/json_object_loader.h"
60
62
  #include "src/core/lib/load_balancing/lb_policy.h"
61
63
  #include "src/core/lib/load_balancing/lb_policy_factory.h"
62
64
  #include "src/core/lib/load_balancing/lb_policy_registry.h"
@@ -82,10 +84,24 @@ constexpr int kMaxAggregateClusterRecursionDepth = 16;
82
84
  // Config for this LB policy.
83
85
  class CdsLbConfig : public LoadBalancingPolicy::Config {
84
86
  public:
85
- explicit CdsLbConfig(std::string cluster) : cluster_(std::move(cluster)) {}
87
+ CdsLbConfig() = default;
88
+
89
+ CdsLbConfig(const CdsLbConfig&) = delete;
90
+ CdsLbConfig& operator=(const CdsLbConfig&) = delete;
91
+
92
+ CdsLbConfig(CdsLbConfig&& other) = delete;
93
+ CdsLbConfig& operator=(CdsLbConfig&& other) = delete;
94
+
86
95
  const std::string& cluster() const { return cluster_; }
87
96
  absl::string_view name() const override { return kCds; }
88
97
 
98
+ static const JsonLoaderInterface* JsonLoader(const JsonArgs&) {
99
+ static const auto* loader = JsonObjectLoader<CdsLbConfig>()
100
+ .Field("cluster", &CdsLbConfig::cluster_)
101
+ .Finish();
102
+ return loader;
103
+ }
104
+
89
105
  private:
90
106
  std::string cluster_;
91
107
  };
@@ -97,7 +113,7 @@ class CdsLb : public LoadBalancingPolicy {
97
113
 
98
114
  absl::string_view name() const override { return kCds; }
99
115
 
100
- void UpdateLocked(UpdateArgs args) override;
116
+ absl::Status UpdateLocked(UpdateArgs args) override;
101
117
  void ResetBackoffLocked() override;
102
118
  void ExitIdleLocked() override;
103
119
 
@@ -309,7 +325,7 @@ void CdsLb::ExitIdleLocked() {
309
325
  if (child_policy_ != nullptr) child_policy_->ExitIdleLocked();
310
326
  }
311
327
 
312
- void CdsLb::UpdateLocked(UpdateArgs args) {
328
+ absl::Status CdsLb::UpdateLocked(UpdateArgs args) {
313
329
  // Update config.
314
330
  auto old_config = std::move(config_);
315
331
  config_ = std::move(args.config);
@@ -337,6 +353,7 @@ void CdsLb::UpdateLocked(UpdateArgs args) {
337
353
  XdsClusterResourceType::StartWatch(xds_client_.get(), config_->cluster(),
338
354
  std::move(watcher));
339
355
  }
356
+ return absl::OkStatus();
340
357
  }
341
358
 
342
359
  // Generates the discovery mechanism config for the specified cluster name.
@@ -517,7 +534,9 @@ void CdsLb::OnClusterChanged(const std::string& name,
517
534
  this, json_str.c_str());
518
535
  }
519
536
  grpc_error_handle error = GRPC_ERROR_NONE;
520
- auto config = LoadBalancingPolicyRegistry::ParseLoadBalancingConfig(json);
537
+ auto config =
538
+ CoreConfiguration::Get().lb_policy_registry().ParseLoadBalancingConfig(
539
+ json);
521
540
  if (!config.ok()) {
522
541
  OnError(name, absl::UnavailableError(config.status().message()));
523
542
  return;
@@ -528,8 +547,10 @@ void CdsLb::OnClusterChanged(const std::string& name,
528
547
  args.work_serializer = work_serializer();
529
548
  args.args = args_;
530
549
  args.channel_control_helper = absl::make_unique<Helper>(Ref());
531
- child_policy_ = LoadBalancingPolicyRegistry::CreateLoadBalancingPolicy(
532
- (*config)->name(), std::move(args));
550
+ child_policy_ =
551
+ CoreConfiguration::Get()
552
+ .lb_policy_registry()
553
+ .CreateLoadBalancingPolicy((*config)->name(), std::move(args));
533
554
  if (child_policy_ == nullptr) {
534
555
  OnError(name, absl::UnavailableError("failed to create child policy"));
535
556
  return;
@@ -549,7 +570,9 @@ void CdsLb::OnClusterChanged(const std::string& name,
549
570
  } else {
550
571
  args.args = args_;
551
572
  }
552
- child_policy_->UpdateLocked(std::move(args));
573
+ // TODO(roth): If the child policy reports an error with the update,
574
+ // we need to propagate the error to the resolver somehow.
575
+ (void)child_policy_->UpdateLocked(std::move(args));
553
576
  }
554
577
  // Remove entries in watchers_ for any clusters not in clusters_added
555
578
  for (auto it = watchers_.begin(); it != watchers_.end();) {
@@ -734,38 +757,16 @@ class CdsLbFactory : public LoadBalancingPolicyFactory {
734
757
  "field:loadBalancingPolicy error:cds policy requires configuration. "
735
758
  "Please use loadBalancingConfig field of service config instead.");
736
759
  }
737
- std::vector<std::string> errors;
738
- // cluster name.
739
- std::string cluster;
740
- auto it = json.object_value().find("cluster");
741
- if (it == json.object_value().end()) {
742
- errors.emplace_back("required field 'cluster' not present");
743
- } else if (it->second.type() != Json::Type::STRING) {
744
- errors.emplace_back("field:cluster error:type should be string");
745
- } else {
746
- cluster = it->second.string_value();
747
- }
748
- if (!errors.empty()) {
749
- return absl::InvalidArgumentError(
750
- absl::StrCat("errors parsing CDS LB policy config: [",
751
- absl::StrJoin(errors, "; "), "]"));
752
- }
753
- return MakeRefCounted<CdsLbConfig>(std::move(cluster));
760
+ return LoadRefCountedFromJson<CdsLbConfig>(
761
+ json, JsonArgs(), "errors validating cds LB policy config");
754
762
  }
755
763
  };
756
764
 
757
765
  } // namespace
758
766
 
759
- } // namespace grpc_core
760
-
761
- //
762
- // Plugin registration
763
- //
764
-
765
- void grpc_lb_policy_cds_init() {
766
- grpc_core::LoadBalancingPolicyRegistry::Builder::
767
- RegisterLoadBalancingPolicyFactory(
768
- absl::make_unique<grpc_core::CdsLbFactory>());
767
+ void RegisterCdsLbPolicy(CoreConfiguration::Builder* builder) {
768
+ builder->lb_policy_registry()->RegisterLoadBalancingPolicyFactory(
769
+ absl::make_unique<CdsLbFactory>());
769
770
  }
770
771
 
771
- void grpc_lb_policy_cds_shutdown() {}
772
+ } // namespace grpc_core