grpc 1.34.0 → 1.37.0

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

Potentially problematic release.


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

Files changed (806) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +893 -2840
  3. data/etc/roots.pem +257 -573
  4. data/include/grpc/compression.h +1 -1
  5. data/include/grpc/grpc.h +28 -0
  6. data/include/grpc/grpc_security.h +77 -14
  7. data/include/grpc/impl/codegen/atm_windows.h +4 -0
  8. data/include/grpc/impl/codegen/byte_buffer.h +1 -1
  9. data/include/grpc/impl/codegen/grpc_types.h +1 -1
  10. data/include/grpc/impl/codegen/log.h +0 -2
  11. data/include/grpc/impl/codegen/port_platform.h +2 -0
  12. data/include/grpc/impl/codegen/sync_windows.h +4 -0
  13. data/include/grpc/slice_buffer.h +3 -3
  14. data/include/grpc/support/sync.h +3 -3
  15. data/include/grpc/support/time.h +7 -7
  16. data/src/core/ext/filters/client_channel/backend_metric.cc +2 -4
  17. data/src/core/ext/filters/client_channel/client_channel.cc +2823 -1559
  18. data/src/core/ext/filters/client_channel/client_channel.h +0 -6
  19. data/src/core/ext/filters/client_channel/client_channel_factory.h +2 -1
  20. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +1 -1
  21. data/src/core/ext/filters/client_channel/config_selector.h +13 -1
  22. data/src/core/ext/filters/client_channel/dynamic_filters.cc +191 -0
  23. data/src/core/ext/filters/client_channel/dynamic_filters.h +99 -0
  24. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +24 -142
  25. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +15 -10
  26. data/src/core/ext/filters/client_channel/health/health_check_client.cc +6 -6
  27. data/src/core/ext/filters/client_channel/health/health_check_client.h +2 -2
  28. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +6 -7
  29. data/src/core/ext/filters/client_channel/http_proxy.cc +21 -20
  30. data/src/core/ext/filters/client_channel/lb_policy.cc +4 -1
  31. data/src/core/ext/filters/client_channel/lb_policy.h +2 -3
  32. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +35 -35
  33. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel.h +1 -2
  34. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -2
  35. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +3 -3
  36. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -1
  37. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +1 -1
  38. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +8 -6
  39. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +23 -0
  40. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +27 -0
  41. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +369 -108
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +0 -8
  43. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +29 -0
  44. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +13 -27
  45. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +2 -2
  46. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +1384 -0
  47. data/src/core/ext/filters/client_channel/local_subchannel_pool.cc +27 -67
  48. data/src/core/ext/filters/client_channel/local_subchannel_pool.h +10 -9
  49. data/src/core/ext/filters/client_channel/resolver.cc +5 -5
  50. data/src/core/ext/filters/client_channel/resolver.h +1 -12
  51. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +41 -57
  52. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +1 -32
  53. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -4
  54. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +3 -1
  55. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +444 -22
  56. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +5 -0
  57. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +21 -22
  58. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +20 -17
  59. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +377 -0
  60. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +21 -34
  61. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +310 -160
  62. data/src/core/ext/filters/client_channel/resolver_factory.h +6 -6
  63. data/src/core/ext/filters/client_channel/resolver_registry.cc +40 -39
  64. data/src/core/ext/filters/client_channel/resolver_registry.h +2 -2
  65. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +11 -13
  66. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +8 -8
  67. data/src/core/ext/filters/client_channel/retry_throttle.cc +5 -3
  68. data/src/core/ext/filters/client_channel/retry_throttle.h +3 -1
  69. data/src/core/ext/filters/client_channel/server_address.cc +9 -0
  70. data/src/core/ext/filters/client_channel/server_address.h +31 -0
  71. data/src/core/ext/filters/client_channel/service_config_call_data.h +19 -1
  72. data/src/core/ext/filters/client_channel/subchannel.cc +100 -193
  73. data/src/core/ext/filters/client_channel/subchannel.h +73 -111
  74. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +16 -2
  75. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +10 -8
  76. data/src/core/ext/filters/client_idle/client_idle_filter.cc +1 -1
  77. data/src/core/ext/filters/deadline/deadline_filter.cc +4 -2
  78. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +495 -0
  79. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +39 -0
  80. data/src/core/ext/filters/fault_injection/service_config_parser.cc +189 -0
  81. data/src/core/ext/filters/fault_injection/service_config_parser.h +85 -0
  82. data/src/core/ext/filters/http/client_authority_filter.cc +6 -6
  83. data/src/core/ext/filters/http/http_filters_plugin.cc +6 -3
  84. data/src/core/ext/filters/max_age/max_age_filter.cc +35 -32
  85. data/src/core/ext/filters/message_size/message_size_filter.cc +1 -1
  86. data/src/core/ext/filters/workarounds/workaround_cronet_compression_filter.cc +1 -1
  87. data/src/core/ext/filters/workarounds/workaround_utils.cc +1 -1
  88. data/src/core/ext/transport/chttp2/client/authority.cc +3 -3
  89. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +2 -2
  90. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +23 -10
  91. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +21 -10
  92. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +29 -16
  93. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +623 -219
  94. data/src/core/ext/transport/chttp2/server/chttp2_server.h +11 -2
  95. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +11 -1
  96. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +12 -5
  97. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +62 -18
  98. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +46 -15
  99. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +12 -1
  100. data/src/core/ext/transport/chttp2/transport/flow_control.h +1 -1
  101. data/src/core/ext/transport/chttp2/transport/frame_data.cc +5 -1
  102. data/src/core/ext/transport/chttp2/transport/frame_settings.h +2 -1
  103. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +6 -6
  104. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +1 -1
  105. data/src/core/ext/transport/chttp2/transport/internal.h +1 -0
  106. data/src/core/ext/transport/chttp2/transport/writing.cc +1 -1
  107. data/src/core/ext/transport/inproc/inproc_transport.cc +42 -8
  108. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +406 -0
  109. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +1459 -0
  110. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +1 -0
  111. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +1 -1
  112. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +7 -0
  113. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +27 -28
  114. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +139 -40
  115. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +350 -0
  116. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1348 -0
  117. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +13 -13
  118. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +44 -17
  119. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +119 -124
  120. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +450 -284
  121. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +3 -3
  122. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +13 -5
  123. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +24 -23
  124. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +62 -21
  125. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +21 -21
  126. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +88 -39
  127. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +4 -4
  128. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +15 -6
  129. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +69 -45
  130. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +275 -78
  131. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +19 -19
  132. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +80 -43
  133. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +1 -1
  134. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +7 -0
  135. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +7 -7
  136. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +27 -11
  137. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +30 -30
  138. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +136 -49
  139. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +41 -41
  140. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +172 -89
  141. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +4 -4
  142. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +17 -9
  143. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +53 -47
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +188 -78
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +1 -2
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +7 -0
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +2 -2
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +9 -2
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +11 -5
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +48 -7
  151. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +13 -14
  152. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +59 -36
  153. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +16 -16
  154. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +61 -29
  155. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +26 -26
  156. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +101 -66
  157. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +2 -2
  158. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +11 -3
  159. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +34 -32
  160. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +151 -61
  161. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +33 -29
  162. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +138 -54
  163. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +2 -3
  164. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +13 -0
  165. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +144 -0
  166. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +488 -0
  167. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +141 -0
  168. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +452 -0
  169. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +16 -16
  170. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +81 -35
  171. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +15 -13
  172. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +70 -37
  173. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +257 -216
  174. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +995 -495
  175. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +5 -5
  176. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +26 -6
  177. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +3 -4
  178. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +17 -3
  179. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +29 -0
  180. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +67 -0
  181. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +79 -0
  182. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +268 -0
  183. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +78 -0
  184. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +281 -0
  185. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +41 -0
  186. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +113 -0
  187. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +96 -98
  188. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +378 -226
  189. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +0 -1
  190. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +1 -0
  191. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +28 -25
  192. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +124 -53
  193. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +9 -12
  194. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +29 -24
  195. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +32 -33
  196. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +118 -67
  197. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.c +1 -1
  198. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +7 -0
  199. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +1 -1
  200. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +7 -0
  201. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +51 -44
  202. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +179 -129
  203. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.c +1 -4
  204. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +7 -0
  205. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.c +1 -4
  206. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +7 -0
  207. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +7 -8
  208. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +31 -16
  209. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.c +1 -3
  210. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +7 -0
  211. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.c +1 -1
  212. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +7 -0
  213. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +93 -0
  214. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +323 -0
  215. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +5 -5
  216. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +25 -11
  217. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +36 -0
  218. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +90 -0
  219. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +1 -1
  220. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +7 -0
  221. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +1 -1
  222. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +7 -0
  223. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +6 -6
  224. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +29 -8
  225. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +2 -3
  226. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +16 -3
  227. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +46 -0
  228. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +124 -0
  229. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +3 -3
  230. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +19 -0
  231. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +7 -7
  232. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +46 -3
  233. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +8 -8
  234. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +41 -8
  235. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +1 -0
  236. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +3 -3
  237. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +15 -2
  238. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +3 -3
  239. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +19 -0
  240. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +1 -1
  241. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +7 -0
  242. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -0
  243. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +34 -34
  244. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +149 -72
  245. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +54 -37
  246. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +171 -59
  247. data/src/core/ext/upb-generated/google/api/http.upb.c +3 -3
  248. data/src/core/ext/upb-generated/google/api/http.upb.h +25 -6
  249. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +1 -1
  250. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +7 -0
  251. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +90 -90
  252. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +455 -292
  253. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +1 -1
  254. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +7 -0
  255. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +1 -1
  256. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +7 -0
  257. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +4 -4
  258. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +22 -3
  259. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +1 -1
  260. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +7 -0
  261. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +9 -9
  262. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +55 -0
  263. data/src/core/ext/upb-generated/google/rpc/status.upb.c +1 -1
  264. data/src/core/ext/upb-generated/google/rpc/status.upb.h +10 -3
  265. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +4 -4
  266. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +11 -3
  267. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +41 -41
  268. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +149 -76
  269. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +5 -5
  270. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +21 -6
  271. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +2 -2
  272. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +13 -0
  273. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +17 -17
  274. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +82 -25
  275. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +3 -3
  276. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +19 -0
  277. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +1 -1
  278. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +7 -0
  279. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +1 -0
  280. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +2 -2
  281. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +9 -2
  282. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +1 -1
  283. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +7 -0
  284. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.c +3 -3
  285. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.h +7 -0
  286. data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.c +33 -0
  287. data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.h +77 -0
  288. data/src/core/ext/upb-generated/validate/validate.upb.c +64 -64
  289. data/src/core/ext/upb-generated/validate/validate.upb.h +296 -157
  290. data/src/core/ext/upb-generated/{udpa/core/v1 → xds/core/v3}/authority.upb.c +6 -6
  291. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +60 -0
  292. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +52 -0
  293. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +143 -0
  294. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +42 -0
  295. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +84 -0
  296. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +36 -0
  297. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +94 -0
  298. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +54 -0
  299. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +166 -0
  300. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +36 -0
  301. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +85 -0
  302. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +354 -0
  303. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +140 -0
  304. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +168 -171
  305. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +383 -0
  306. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +115 -0
  307. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +405 -420
  308. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +2 -2
  309. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +12 -9
  310. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +177 -171
  311. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +10 -0
  312. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +88 -88
  313. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +153 -153
  314. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +10 -7
  315. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +5 -0
  316. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +4 -7
  317. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +33 -20
  318. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +56 -59
  319. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +116 -111
  320. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +129 -121
  321. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +21 -24
  322. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +141 -0
  323. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +70 -0
  324. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +141 -0
  325. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +70 -0
  326. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +17 -13
  327. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +753 -724
  328. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +10 -0
  329. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +22 -25
  330. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +51 -0
  331. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +35 -0
  332. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +102 -0
  333. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +55 -0
  334. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +120 -0
  335. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +45 -0
  336. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +76 -0
  337. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +35 -0
  338. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +371 -377
  339. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +12 -16
  340. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +112 -108
  341. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +45 -53
  342. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +177 -180
  343. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +92 -102
  344. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +5 -0
  345. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.c +32 -42
  346. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.c +30 -40
  347. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +4 -7
  348. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.c +38 -44
  349. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +130 -0
  350. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +50 -0
  351. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +56 -0
  352. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +35 -0
  353. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +30 -33
  354. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +63 -0
  355. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +40 -0
  356. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +8 -7
  357. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +9 -9
  358. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +9 -8
  359. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +8 -8
  360. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +8 -8
  361. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +9 -8
  362. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +8 -8
  363. data/src/core/ext/upbdefs-generated/udpa/type/v1/typed_struct.upbdefs.c +44 -0
  364. data/src/core/ext/upbdefs-generated/udpa/type/v1/typed_struct.upbdefs.h +35 -0
  365. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +14 -11
  366. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +42 -0
  367. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +35 -0
  368. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +62 -0
  369. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +40 -0
  370. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +45 -0
  371. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +40 -0
  372. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +49 -0
  373. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +35 -0
  374. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +67 -0
  375. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +40 -0
  376. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +50 -0
  377. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +35 -0
  378. data/src/core/ext/xds/certificate_provider_store.cc +10 -7
  379. data/src/core/ext/xds/certificate_provider_store.h +12 -7
  380. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +25 -0
  381. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +1 -4
  382. data/src/core/ext/xds/xds_api.cc +2265 -593
  383. data/src/core/ext/xds/xds_api.h +335 -102
  384. data/src/core/ext/xds/xds_bootstrap.cc +80 -45
  385. data/src/core/ext/xds/xds_bootstrap.h +17 -6
  386. data/src/core/ext/xds/xds_certificate_provider.cc +232 -67
  387. data/src/core/ext/xds/xds_certificate_provider.h +103 -26
  388. data/src/core/ext/xds/xds_client.cc +212 -63
  389. data/src/core/ext/xds/xds_client.h +35 -1
  390. data/src/core/ext/xds/xds_client_stats.cc +4 -3
  391. data/src/core/ext/xds/xds_client_stats.h +2 -2
  392. data/src/core/ext/xds/xds_http_fault_filter.cc +226 -0
  393. data/src/core/ext/xds/xds_http_fault_filter.h +63 -0
  394. data/src/core/ext/xds/xds_http_filters.cc +114 -0
  395. data/src/core/ext/xds/xds_http_filters.h +130 -0
  396. data/src/core/ext/xds/xds_server_config_fetcher.cc +532 -0
  397. data/src/core/lib/channel/channel_args.cc +8 -8
  398. data/src/core/lib/channel/channel_stack.cc +12 -0
  399. data/src/core/lib/channel/channel_stack.h +7 -0
  400. data/src/core/lib/channel/channel_trace.h +1 -1
  401. data/src/core/lib/channel/channelz.cc +105 -18
  402. data/src/core/lib/channel/channelz.h +30 -2
  403. data/src/core/lib/channel/channelz_registry.cc +14 -0
  404. data/src/core/lib/channel/channelz_registry.h +0 -1
  405. data/src/core/lib/channel/handshaker.cc +4 -46
  406. data/src/core/lib/channel/handshaker.h +1 -18
  407. data/src/core/lib/channel/status_util.cc +12 -2
  408. data/src/core/lib/channel/status_util.h +5 -0
  409. data/src/core/lib/compression/compression_args.cc +3 -2
  410. data/src/core/lib/debug/stats.h +2 -2
  411. data/src/core/lib/debug/stats_data.h +13 -13
  412. data/src/core/lib/gpr/alloc.cc +3 -2
  413. data/src/core/lib/gpr/log.cc +59 -17
  414. data/src/core/lib/gpr/log_linux.cc +3 -1
  415. data/src/core/lib/gpr/log_posix.cc +3 -1
  416. data/src/core/lib/gpr/log_windows.cc +3 -1
  417. data/src/core/lib/gpr/spinlock.h +10 -2
  418. data/src/core/lib/gpr/string.cc +22 -21
  419. data/src/core/lib/gpr/string.h +5 -6
  420. data/src/core/lib/gpr/sync.cc +4 -4
  421. data/src/core/lib/gpr/sync_abseil.cc +3 -6
  422. data/src/core/lib/gpr/sync_windows.cc +2 -2
  423. data/src/core/lib/gpr/time.cc +12 -12
  424. data/src/core/lib/gprpp/arena.h +3 -2
  425. data/src/core/lib/gprpp/atomic.h +3 -3
  426. data/src/core/lib/gprpp/dual_ref_counted.h +3 -3
  427. data/src/core/lib/gprpp/mpscq.cc +2 -2
  428. data/src/core/lib/gprpp/ref_counted.h +2 -2
  429. data/src/core/lib/gprpp/ref_counted_ptr.h +11 -1
  430. data/src/core/lib/gprpp/sync.h +129 -40
  431. data/src/core/lib/gprpp/thd.h +1 -1
  432. data/src/core/lib/gprpp/thd_posix.cc +6 -1
  433. data/src/core/lib/gprpp/thd_windows.cc +3 -1
  434. data/src/core/lib/gprpp/time_util.cc +77 -0
  435. data/src/core/lib/gprpp/time_util.h +42 -0
  436. data/src/core/lib/http/httpcli.cc +1 -1
  437. data/src/core/lib/http/httpcli.h +2 -3
  438. data/src/core/lib/http/httpcli_security_connector.cc +3 -3
  439. data/src/core/lib/http/parser.cc +1 -2
  440. data/src/core/lib/iomgr/buffer_list.h +1 -1
  441. data/src/core/lib/iomgr/call_combiner.cc +8 -5
  442. data/src/core/lib/iomgr/cfstream_handle.cc +2 -2
  443. data/src/core/lib/iomgr/combiner.cc +2 -1
  444. data/src/core/lib/iomgr/endpoint.h +1 -1
  445. data/src/core/lib/iomgr/error.cc +15 -11
  446. data/src/core/lib/iomgr/error.h +1 -1
  447. data/src/core/lib/iomgr/error_internal.h +1 -1
  448. data/src/core/lib/iomgr/ev_apple.cc +11 -8
  449. data/src/core/lib/iomgr/ev_epoll1_linux.cc +23 -16
  450. data/src/core/lib/iomgr/ev_epollex_linux.cc +21 -17
  451. data/src/core/lib/iomgr/ev_poll_posix.cc +9 -7
  452. data/src/core/lib/iomgr/ev_posix.cc +3 -3
  453. data/src/core/lib/iomgr/exec_ctx.cc +6 -2
  454. data/src/core/lib/iomgr/exec_ctx.h +6 -4
  455. data/src/core/lib/iomgr/executor.cc +2 -1
  456. data/src/core/lib/iomgr/executor.h +1 -1
  457. data/src/core/lib/iomgr/executor/threadpool.h +1 -1
  458. data/src/core/lib/iomgr/iomgr.cc +1 -1
  459. data/src/core/lib/iomgr/iomgr_posix.cc +0 -1
  460. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +0 -1
  461. data/src/core/lib/iomgr/load_file.h +1 -1
  462. data/src/core/lib/iomgr/lockfree_event.cc +19 -14
  463. data/src/core/lib/iomgr/lockfree_event.h +2 -2
  464. data/src/core/lib/iomgr/parse_address.cc +52 -46
  465. data/src/core/lib/iomgr/parse_address.h +13 -9
  466. data/src/core/lib/iomgr/poller/eventmanager_libuv.h +1 -1
  467. data/src/core/lib/iomgr/pollset_set_custom.cc +1 -1
  468. data/src/core/lib/iomgr/python_util.h +1 -1
  469. data/src/core/lib/iomgr/resolve_address.cc +4 -4
  470. data/src/core/lib/iomgr/resource_quota.cc +5 -5
  471. data/src/core/lib/iomgr/sockaddr_utils.cc +131 -11
  472. data/src/core/lib/iomgr/sockaddr_utils.h +26 -1
  473. data/src/core/lib/iomgr/socket_factory_posix.cc +3 -2
  474. data/src/core/lib/iomgr/socket_mutator.cc +3 -2
  475. data/src/core/lib/iomgr/socket_utils_common_posix.cc +1 -0
  476. data/src/core/lib/iomgr/tcp_client.cc +3 -3
  477. data/src/core/lib/iomgr/tcp_client_custom.cc +7 -6
  478. data/src/core/lib/iomgr/tcp_client_posix.cc +1 -1
  479. data/src/core/lib/iomgr/tcp_custom.cc +22 -17
  480. data/src/core/lib/iomgr/tcp_posix.cc +14 -14
  481. data/src/core/lib/iomgr/tcp_server_custom.cc +28 -22
  482. data/src/core/lib/iomgr/tcp_uv.cc +2 -2
  483. data/src/core/lib/iomgr/timer_custom.cc +3 -3
  484. data/src/core/lib/iomgr/timer_generic.cc +5 -5
  485. data/src/core/lib/iomgr/timer_manager.cc +3 -3
  486. data/src/core/lib/iomgr/udp_server.cc +1 -2
  487. data/src/core/lib/iomgr/udp_server.h +1 -2
  488. data/src/core/lib/iomgr/unix_sockets_posix.cc +17 -18
  489. data/src/core/lib/iomgr/wakeup_fd_nospecial.cc +1 -1
  490. data/src/core/lib/json/json.h +10 -0
  491. data/src/core/lib/matchers/matchers.cc +339 -0
  492. data/src/core/lib/matchers/matchers.h +160 -0
  493. data/src/core/lib/security/context/security_context.cc +4 -3
  494. data/src/core/lib/security/credentials/alts/alts_credentials.cc +2 -1
  495. data/src/core/lib/security/credentials/alts/alts_credentials.h +1 -1
  496. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +1 -1
  497. data/src/core/lib/security/credentials/credentials.cc +6 -6
  498. data/src/core/lib/security/credentials/credentials.h +2 -1
  499. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +413 -0
  500. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +80 -0
  501. data/src/core/lib/security/credentials/external/aws_request_signer.cc +15 -10
  502. data/src/core/lib/security/credentials/external/aws_request_signer.h +1 -2
  503. data/src/core/lib/security/credentials/external/external_account_credentials.cc +217 -31
  504. data/src/core/lib/security/credentials/external/external_account_credentials.h +7 -5
  505. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +5 -6
  506. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +3 -4
  507. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +20 -18
  508. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +5 -6
  509. data/src/core/lib/security/credentials/fake/fake_credentials.cc +3 -2
  510. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +25 -18
  511. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +18 -5
  512. data/src/core/lib/security/credentials/jwt/json_token.cc +1 -4
  513. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +3 -6
  514. data/src/core/lib/security/credentials/local/local_credentials.cc +2 -1
  515. data/src/core/lib/security/credentials/local/local_credentials.h +1 -1
  516. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +37 -44
  517. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +5 -4
  518. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +1 -1
  519. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +7 -6
  520. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +2 -2
  521. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +1 -6
  522. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +1 -6
  523. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +326 -5
  524. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +64 -0
  525. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +1 -1
  526. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +0 -1
  527. data/src/core/lib/security/credentials/tls/tls_credentials.cc +3 -2
  528. data/src/core/lib/security/credentials/tls/tls_credentials.h +1 -1
  529. data/src/core/lib/security/credentials/tls/tls_utils.cc +91 -0
  530. data/src/core/lib/security/credentials/tls/tls_utils.h +38 -0
  531. data/src/core/lib/security/credentials/xds/xds_credentials.cc +209 -10
  532. data/src/core/lib/security/credentials/xds/xds_credentials.h +27 -9
  533. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +1 -1
  534. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +1 -1
  535. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +50 -17
  536. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +23 -6
  537. data/src/core/lib/security/security_connector/local/local_security_connector.cc +1 -1
  538. data/src/core/lib/security/security_connector/security_connector.cc +3 -2
  539. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +4 -4
  540. data/src/core/lib/security/security_connector/ssl_utils.cc +11 -6
  541. data/src/core/lib/security/security_connector/ssl_utils.h +12 -19
  542. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +89 -26
  543. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +2 -3
  544. data/src/core/lib/security/transport/secure_endpoint.cc +2 -2
  545. data/src/core/lib/security/transport/security_handshaker.cc +35 -7
  546. data/src/core/lib/slice/slice_intern.cc +9 -11
  547. data/src/core/lib/slice/slice_internal.h +2 -2
  548. data/src/core/lib/surface/call.cc +32 -24
  549. data/src/core/lib/surface/call_details.cc +8 -8
  550. data/src/core/lib/surface/channel.cc +16 -10
  551. data/src/core/lib/surface/channel.h +6 -5
  552. data/src/core/lib/surface/channel_init.cc +1 -1
  553. data/src/core/lib/surface/completion_queue.cc +24 -19
  554. data/src/core/lib/surface/completion_queue.h +16 -16
  555. data/src/core/lib/surface/init.cc +19 -20
  556. data/src/core/lib/surface/lame_client.cc +47 -54
  557. data/src/core/lib/surface/lame_client.h +5 -0
  558. data/src/core/lib/surface/server.cc +102 -51
  559. data/src/core/lib/surface/server.h +112 -18
  560. data/src/core/lib/surface/version.cc +2 -2
  561. data/src/core/lib/transport/authority_override.cc +6 -4
  562. data/src/core/lib/transport/authority_override.h +5 -2
  563. data/src/core/lib/transport/connectivity_state.h +6 -4
  564. data/src/core/lib/transport/error_utils.h +1 -1
  565. data/src/core/lib/transport/metadata.cc +6 -2
  566. data/src/core/lib/transport/metadata_batch.cc +27 -0
  567. data/src/core/lib/transport/metadata_batch.h +18 -4
  568. data/src/core/lib/transport/static_metadata.cc +1 -1
  569. data/src/core/lib/transport/status_metadata.cc +4 -3
  570. data/src/core/lib/transport/transport.h +7 -7
  571. data/src/core/lib/uri/uri_parser.cc +131 -249
  572. data/src/core/lib/uri/uri_parser.h +57 -21
  573. data/src/core/plugin_registry/grpc_plugin_registry.cc +22 -4
  574. data/src/core/tsi/alts/crypt/gsec.cc +5 -4
  575. data/src/core/tsi/alts/frame_protector/frame_handler.cc +8 -6
  576. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +19 -25
  577. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +39 -44
  578. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +1 -1
  579. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +1 -3
  580. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +8 -6
  581. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +4 -4
  582. data/src/core/tsi/fake_transport_security.cc +16 -5
  583. data/src/core/tsi/ssl/session_cache/ssl_session.h +0 -3
  584. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +1 -1
  585. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +0 -2
  586. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +2 -4
  587. data/src/core/tsi/ssl_transport_security.cc +62 -52
  588. data/src/core/tsi/ssl_transport_security.h +6 -9
  589. data/src/core/tsi/transport_security.cc +6 -6
  590. data/src/core/tsi/transport_security_interface.h +1 -1
  591. data/src/ruby/ext/grpc/extconf.rb +9 -1
  592. data/src/ruby/ext/grpc/rb_channel.c +10 -1
  593. data/src/ruby/ext/grpc/rb_channel_credentials.c +11 -1
  594. data/src/ruby/ext/grpc/rb_channel_credentials.h +4 -0
  595. data/src/ruby/ext/grpc/rb_compression_options.c +1 -1
  596. data/src/ruby/ext/grpc/rb_enable_cpp.cc +1 -1
  597. data/src/ruby/ext/grpc/rb_event_thread.c +2 -0
  598. data/src/ruby/ext/grpc/rb_grpc.c +4 -0
  599. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +14 -0
  600. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +34 -13
  601. data/src/ruby/ext/grpc/rb_server.c +13 -1
  602. data/src/ruby/ext/grpc/rb_server_credentials.c +19 -3
  603. data/src/ruby/ext/grpc/rb_server_credentials.h +4 -0
  604. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +215 -0
  605. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +35 -0
  606. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +169 -0
  607. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +35 -0
  608. data/src/ruby/lib/grpc/generic/client_stub.rb +4 -2
  609. data/src/ruby/lib/grpc/version.rb +1 -1
  610. data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +35 -0
  611. data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +18 -0
  612. data/src/ruby/spec/call_spec.rb +1 -1
  613. data/src/ruby/spec/channel_credentials_spec.rb +32 -0
  614. data/src/ruby/spec/channel_spec.rb +17 -6
  615. data/src/ruby/spec/client_auth_spec.rb +27 -1
  616. data/src/ruby/spec/errors_spec.rb +1 -1
  617. data/src/ruby/spec/generic/active_call_spec.rb +2 -2
  618. data/src/ruby/spec/generic/client_stub_spec.rb +4 -4
  619. data/src/ruby/spec/generic/rpc_server_spec.rb +1 -1
  620. data/src/ruby/spec/pb/codegen/package_option_spec.rb +2 -6
  621. data/src/ruby/spec/server_credentials_spec.rb +25 -0
  622. data/src/ruby/spec/server_spec.rb +22 -0
  623. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +606 -0
  624. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +197 -0
  625. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +399 -0
  626. data/third_party/abseil-cpp/absl/status/statusor.cc +71 -0
  627. data/third_party/abseil-cpp/absl/status/statusor.h +760 -0
  628. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +1 -0
  629. data/third_party/boringssl-with-bazel/err_data.c +715 -713
  630. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +3 -3
  631. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_enum.c +2 -2
  632. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +5 -5
  633. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +3 -10
  634. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +3 -3
  635. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +4 -2
  636. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +2 -2
  637. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +15 -14
  638. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_locl.h +30 -0
  639. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +28 -79
  640. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +39 -85
  641. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +5 -16
  642. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +10 -61
  643. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +0 -2
  644. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +2 -2
  645. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +4 -0
  646. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +158 -0
  647. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/bn_asn1.c +3 -10
  648. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +8 -9
  649. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +60 -45
  650. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +6 -81
  651. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +87 -0
  652. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-win.c +41 -0
  653. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm-linux.c +11 -2
  654. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm.c +3 -3
  655. data/third_party/boringssl-with-bazel/src/crypto/{dh → dh_extra}/dh_asn1.c +0 -0
  656. data/third_party/boringssl-with-bazel/src/crypto/{dh → dh_extra}/params.c +179 -0
  657. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +25 -0
  658. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +2 -17
  659. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +3 -1
  660. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +13 -20
  661. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +2 -3
  662. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +9 -1
  663. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +21 -13
  664. data/third_party/boringssl-with-bazel/src/crypto/{dh → fipsmodule/dh}/check.c +0 -0
  665. data/third_party/boringssl-with-bazel/src/crypto/{dh → fipsmodule/dh}/dh.c +136 -213
  666. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +12 -0
  667. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +9 -1
  668. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +28 -0
  669. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +135 -43
  670. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +0 -7
  671. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +51 -32
  672. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +147 -0
  673. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +18 -29
  674. data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +13 -4
  675. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +10 -7
  676. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +13 -11
  677. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +4 -0
  678. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +34 -0
  679. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +4 -0
  680. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +7 -13
  681. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +5 -1
  682. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +1 -29
  683. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +10 -7
  684. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_r2x.c +1 -1
  685. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +8 -8
  686. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +1 -1
  687. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +29 -23
  688. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +22 -17
  689. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +1 -2
  690. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pkey.c +2 -2
  691. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +39 -4
  692. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +2 -2
  693. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +3 -3
  694. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +11 -10
  695. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +3 -3
  696. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +25 -25
  697. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +2 -2
  698. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +2 -1
  699. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +40 -20
  700. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ia5.c +3 -4
  701. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +25 -36
  702. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +1 -1
  703. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +6 -6
  704. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +6 -6
  705. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +3 -3
  706. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +652 -545
  707. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +0 -167
  708. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +10 -5
  709. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +62 -0
  710. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +22 -7
  711. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +19 -0
  712. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +22 -32
  713. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +56 -26
  714. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +1 -0
  715. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +15 -0
  716. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +12 -2
  717. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +3 -0
  718. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +2 -1
  719. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +67 -33
  720. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +27 -8
  721. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +287 -99
  722. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +139 -36
  723. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +4 -3
  724. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +11 -20
  725. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +10 -5
  726. data/third_party/boringssl-with-bazel/src/ssl/internal.h +37 -16
  727. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +0 -1
  728. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +7 -8
  729. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +20 -14
  730. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +7 -8
  731. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +2 -2
  732. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +5 -7
  733. data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +362 -50
  734. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +2 -2
  735. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +48 -15
  736. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +66 -24
  737. data/third_party/upb/third_party/wyhash/wyhash.h +145 -0
  738. data/third_party/upb/upb/decode.c +248 -167
  739. data/third_party/upb/upb/decode.h +20 -1
  740. data/third_party/upb/upb/decode.int.h +163 -0
  741. data/third_party/upb/upb/decode_fast.c +1040 -0
  742. data/third_party/upb/upb/decode_fast.h +126 -0
  743. data/third_party/upb/upb/def.c +525 -516
  744. data/third_party/upb/upb/def.h +16 -31
  745. data/third_party/upb/upb/def.hpp +37 -123
  746. data/third_party/upb/upb/encode.c +227 -169
  747. data/third_party/upb/upb/encode.h +27 -2
  748. data/third_party/upb/upb/msg.c +167 -88
  749. data/third_party/upb/upb/msg.h +174 -34
  750. data/third_party/upb/upb/port_def.inc +74 -61
  751. data/third_party/upb/upb/port_undef.inc +3 -7
  752. data/third_party/upb/upb/reflection.c +36 -19
  753. data/third_party/upb/upb/table.c +34 -197
  754. data/third_party/upb/upb/table.int.h +14 -5
  755. data/third_party/upb/upb/text_encode.c +45 -22
  756. data/third_party/upb/upb/text_encode.h +4 -1
  757. data/third_party/upb/upb/upb.c +18 -41
  758. data/third_party/upb/upb/upb.h +36 -7
  759. data/third_party/upb/upb/upb.hpp +4 -4
  760. data/third_party/upb/upb/upb.int.h +29 -0
  761. data/third_party/xxhash/xxhash.h +5443 -0
  762. metadata +152 -82
  763. data/src/core/ext/filters/client_channel/lb_policy/xds/eds.cc +0 -909
  764. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.cc +0 -485
  765. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_fallback.cc +0 -68
  766. data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +0 -355
  767. data/src/core/ext/filters/client_channel/resolving_lb_policy.h +0 -138
  768. data/src/core/ext/upb-generated/udpa/core/v1/authority.upb.h +0 -53
  769. data/src/core/ext/upb-generated/udpa/core/v1/collection_entry.upb.c +0 -52
  770. data/src/core/ext/upb-generated/udpa/core/v1/collection_entry.upb.h +0 -129
  771. data/src/core/ext/upb-generated/udpa/core/v1/context_params.upb.c +0 -42
  772. data/src/core/ext/upb-generated/udpa/core/v1/context_params.upb.h +0 -77
  773. data/src/core/ext/upb-generated/udpa/core/v1/resource.upb.c +0 -36
  774. data/src/core/ext/upb-generated/udpa/core/v1/resource.upb.h +0 -85
  775. data/src/core/ext/upb-generated/udpa/core/v1/resource_locator.upb.c +0 -54
  776. data/src/core/ext/upb-generated/udpa/core/v1/resource_locator.upb.h +0 -160
  777. data/src/core/ext/upb-generated/udpa/core/v1/resource_name.upb.c +0 -36
  778. data/src/core/ext/upb-generated/udpa/core/v1/resource_name.upb.h +0 -84
  779. data/src/core/ext/upbdefs-generated/udpa/core/v1/authority.upbdefs.c +0 -42
  780. data/src/core/ext/upbdefs-generated/udpa/core/v1/authority.upbdefs.h +0 -35
  781. data/src/core/ext/upbdefs-generated/udpa/core/v1/collection_entry.upbdefs.c +0 -62
  782. data/src/core/ext/upbdefs-generated/udpa/core/v1/collection_entry.upbdefs.h +0 -40
  783. data/src/core/ext/upbdefs-generated/udpa/core/v1/context_params.upbdefs.c +0 -45
  784. data/src/core/ext/upbdefs-generated/udpa/core/v1/context_params.upbdefs.h +0 -40
  785. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource.upbdefs.c +0 -49
  786. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource.upbdefs.h +0 -35
  787. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_locator.upbdefs.c +0 -68
  788. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_locator.upbdefs.h +0 -40
  789. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_name.upbdefs.c +0 -51
  790. data/src/core/ext/upbdefs-generated/udpa/core/v1/resource_name.upbdefs.h +0 -35
  791. data/src/core/ext/xds/google_mesh_ca_certificate_provider_factory.cc +0 -265
  792. data/src/core/ext/xds/google_mesh_ca_certificate_provider_factory.h +0 -104
  793. data/src/core/lib/gprpp/map.h +0 -53
  794. data/src/core/lib/iomgr/iomgr_posix.h +0 -26
  795. data/src/core/lib/security/authorization/authorization_engine.cc +0 -177
  796. data/src/core/lib/security/authorization/authorization_engine.h +0 -84
  797. data/src/core/lib/security/authorization/evaluate_args.cc +0 -153
  798. data/src/core/lib/security/authorization/evaluate_args.h +0 -59
  799. data/src/core/lib/security/authorization/mock_cel/activation.h +0 -57
  800. data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +0 -44
  801. data/src/core/lib/security/authorization/mock_cel/cel_expression.h +0 -69
  802. data/src/core/lib/security/authorization/mock_cel/cel_value.h +0 -97
  803. data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +0 -67
  804. data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +0 -57
  805. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +0 -504
  806. data/third_party/upb/upb/port.c +0 -26
@@ -33,8 +33,7 @@ namespace grpc_core {
33
33
  /// Takes ownership of \a args.
34
34
  ///
35
35
  /// Caller takes ownership of the returned args.
36
- grpc_channel_args* ModifyGrpclbBalancerChannelArgs(
37
- const ServerAddressList& addresses, grpc_channel_args* args);
36
+ grpc_channel_args* ModifyGrpclbBalancerChannelArgs(grpc_channel_args* args);
38
37
 
39
38
  grpc_channel* CreateGrpclbBalancerChannel(const char* target_uri,
40
39
  const grpc_channel_args& args);
@@ -39,8 +39,7 @@
39
39
 
40
40
  namespace grpc_core {
41
41
 
42
- grpc_channel_args* ModifyGrpclbBalancerChannelArgs(
43
- const ServerAddressList& addresses, grpc_channel_args* args) {
42
+ grpc_channel_args* ModifyGrpclbBalancerChannelArgs(grpc_channel_args* args) {
44
43
  absl::InlinedVector<const char*, 1> args_to_remove;
45
44
  absl::InlinedVector<grpc_arg, 1> args_to_add;
46
45
  // Substitute the channel credentials with a version without call
@@ -155,13 +155,13 @@ grpc_millis grpc_grpclb_duration_to_millis(
155
155
 
156
156
  } // namespace
157
157
 
158
- bool GrpcLbResponseParse(const grpc_slice& encoded_grpc_grpclb_response,
158
+ bool GrpcLbResponseParse(const grpc_slice& serialized_response,
159
159
  upb_arena* arena, GrpcLbResponse* result) {
160
160
  grpc_lb_v1_LoadBalanceResponse* response =
161
161
  grpc_lb_v1_LoadBalanceResponse_parse(
162
162
  reinterpret_cast<const char*>(
163
- GRPC_SLICE_START_PTR(encoded_grpc_grpclb_response)),
164
- GRPC_SLICE_LENGTH(encoded_grpc_grpclb_response), arena);
163
+ GRPC_SLICE_START_PTR(serialized_response)),
164
+ GRPC_SLICE_LENGTH(serialized_response), arena);
165
165
  // Handle serverlist responses.
166
166
  if (ParseServerList(*response, &result->serverlist)) {
167
167
  result->type = result->SERVERLIST;
@@ -66,7 +66,7 @@ grpc_slice GrpcLbLoadReportRequestCreate(
66
66
 
67
67
  // Deserialize a grpclb response.
68
68
  bool GrpcLbResponseParse(const grpc_slice& serialized_response,
69
- upb_arena* arena, GrpcLbResponse* response);
69
+ upb_arena* arena, GrpcLbResponse* result);
70
70
 
71
71
  } // namespace grpc_core
72
72
 
@@ -497,7 +497,7 @@ class PickFirstFactory : public LoadBalancingPolicyFactory {
497
497
  const char* name() const override { return kPickFirst; }
498
498
 
499
499
  RefCountedPtr<LoadBalancingPolicy::Config> ParseLoadBalancingConfig(
500
- const Json& json, grpc_error** /*error*/) const override {
500
+ const Json& /*json*/, grpc_error** /*error*/) const override {
501
501
  return MakeRefCounted<PickFirstConfig>();
502
502
  }
503
503
  };
@@ -363,8 +363,10 @@ void PriorityLb::HandleChildConnectivityStateChangeLocked(
363
363
  // Otherwise, find the child's priority.
364
364
  uint32_t child_priority = GetChildPriorityLocked(child->name());
365
365
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_priority_trace)) {
366
- gpr_log(GPR_INFO, "[priority_lb %p] state update for priority %d, child %s",
367
- this, child_priority, child->name().c_str());
366
+ gpr_log(GPR_INFO,
367
+ "[priority_lb %p] state update for priority %u, child %s, current "
368
+ "priority %u",
369
+ this, child_priority, child->name().c_str(), current_priority_);
368
370
  }
369
371
  // Ignore priorities not in the current config.
370
372
  if (child_priority == UINT32_MAX) return;
@@ -412,12 +414,13 @@ void PriorityLb::DeleteChild(ChildPriority* child) {
412
414
  }
413
415
 
414
416
  void PriorityLb::TryNextPriorityLocked(bool report_connecting) {
417
+ current_priority_ = UINT32_MAX;
415
418
  for (uint32_t priority = 0; priority < config_->priorities().size();
416
419
  ++priority) {
417
420
  // If the child for the priority does not exist yet, create it.
418
421
  const std::string& child_name = config_->priorities()[priority];
419
422
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_priority_trace)) {
420
- gpr_log(GPR_INFO, "[priority_lb %p] trying priority %d, child %s", this,
423
+ gpr_log(GPR_INFO, "[priority_lb %p] trying priority %u, child %s", this,
421
424
  priority, child_name.c_str());
422
425
  }
423
426
  auto& child = children_[child_name];
@@ -448,7 +451,7 @@ void PriorityLb::TryNextPriorityLocked(bool report_connecting) {
448
451
  if (child->failover_timer_callback_pending()) {
449
452
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_priority_trace)) {
450
453
  gpr_log(GPR_INFO,
451
- "[priority_lb %p] priority %d, child %s: child still "
454
+ "[priority_lb %p] priority %u, child %s: child still "
452
455
  "attempting to connect, will wait",
453
456
  this, priority, child_name.c_str());
454
457
  }
@@ -468,7 +471,6 @@ void PriorityLb::TryNextPriorityLocked(bool report_connecting) {
468
471
  "TRANSIENT_FAILURE",
469
472
  this);
470
473
  }
471
- current_priority_ = UINT32_MAX;
472
474
  current_child_from_before_update_ = nullptr;
473
475
  grpc_error* error = grpc_error_set_int(
474
476
  GRPC_ERROR_CREATE_FROM_STATIC_STRING("no ready priority"),
@@ -480,7 +482,7 @@ void PriorityLb::TryNextPriorityLocked(bool report_connecting) {
480
482
 
481
483
  void PriorityLb::SelectPriorityLocked(uint32_t priority) {
482
484
  if (GRPC_TRACE_FLAG_ENABLED(grpc_lb_priority_trace)) {
483
- gpr_log(GPR_INFO, "[priority_lb %p] selected priority %d, child %s", this,
485
+ gpr_log(GPR_INFO, "[priority_lb %p] selected priority %u, child %s", this,
484
486
  priority, config_->priorities()[priority].c_str());
485
487
  }
486
488
  current_priority_ = priority;
@@ -0,0 +1,23 @@
1
+ //
2
+ // Copyright 2018 gRPC authors.
3
+ //
4
+ // Licensed under the Apache License, Version 2.0 (the "License");
5
+ // you may not use this file except in compliance with the License.
6
+ // You may obtain a copy of the License at
7
+ //
8
+ // http://www.apache.org/licenses/LICENSE-2.0
9
+ //
10
+ // Unless required by applicable law or agreed to in writing, software
11
+ // distributed under the License is distributed on an "AS IS" BASIS,
12
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ // See the License for the specific language governing permissions and
14
+ // limitations under the License.
15
+ //
16
+
17
+ #include <grpc/support/port_platform.h>
18
+
19
+ namespace grpc_core {
20
+
21
+ const char* kRequestRingHashAttribute = "request_ring_hash";
22
+
23
+ } // namespace grpc_core
@@ -0,0 +1,27 @@
1
+ //
2
+ // Copyright 2018 gRPC authors.
3
+ //
4
+ // Licensed under the Apache License, Version 2.0 (the "License");
5
+ // you may not use this file except in compliance with the License.
6
+ // You may obtain a copy of the License at
7
+ //
8
+ // http://www.apache.org/licenses/LICENSE-2.0
9
+ //
10
+ // Unless required by applicable law or agreed to in writing, software
11
+ // distributed under the License is distributed on an "AS IS" BASIS,
12
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ // See the License for the specific language governing permissions and
14
+ // limitations under the License.
15
+ //
16
+
17
+ #ifndef GRPC_CORE_EXT_FILTERS_CLIENT_CHANNEL_LB_POLICY_RING_HASH_RING_HASH_H
18
+ #define GRPC_CORE_EXT_FILTERS_CLIENT_CHANNEL_LB_POLICY_RING_HASH_RING_HASH_H
19
+
20
+ #include <grpc/support/port_platform.h>
21
+
22
+ namespace grpc_core {
23
+ extern const char* kRequestRingHashAttribute;
24
+
25
+ } // namespace grpc_core
26
+
27
+ #endif // GRPC_CORE_EXT_FILTERS_CLIENT_CHANNEL_LB_POLICY_RING_HASH_RING_HASH_H
@@ -24,6 +24,7 @@
24
24
  #include "src/core/ext/filters/client_channel/lb_policy_factory.h"
25
25
  #include "src/core/ext/filters/client_channel/lb_policy_registry.h"
26
26
  #include "src/core/ext/filters/client_channel/service_config.h"
27
+ #include "src/core/ext/xds/xds_certificate_provider.h"
27
28
  #include "src/core/ext/xds/xds_client.h"
28
29
  #include "src/core/lib/channel/channel_args.h"
29
30
  #include "src/core/lib/gprpp/memory.h"
@@ -31,6 +32,7 @@
31
32
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
32
33
  #include "src/core/lib/iomgr/closure.h"
33
34
  #include "src/core/lib/iomgr/exec_ctx.h"
35
+ #include "src/core/lib/security/credentials/xds/xds_credentials.h"
34
36
  #include "src/core/lib/transport/error_utils.h"
35
37
 
36
38
  namespace grpc_core {
@@ -61,26 +63,31 @@ class CdsLb : public LoadBalancingPolicy {
61
63
 
62
64
  void UpdateLocked(UpdateArgs args) override;
63
65
  void ResetBackoffLocked() override;
66
+ void ExitIdleLocked() override;
64
67
 
65
68
  private:
66
69
  // Watcher for getting cluster data from XdsClient.
67
70
  class ClusterWatcher : public XdsClient::ClusterWatcherInterface {
68
71
  public:
69
- explicit ClusterWatcher(RefCountedPtr<CdsLb> parent)
70
- : parent_(std::move(parent)) {}
72
+ ClusterWatcher(RefCountedPtr<CdsLb> parent, std::string name)
73
+ : parent_(std::move(parent)), name_(std::move(name)) {}
71
74
 
72
75
  void OnClusterChanged(XdsApi::CdsUpdate cluster_data) override {
73
- new Notifier(parent_, std::move(cluster_data));
76
+ new Notifier(parent_, name_, std::move(cluster_data));
74
77
  }
75
- void OnError(grpc_error* error) override { new Notifier(parent_, error); }
76
- void OnResourceDoesNotExist() override { new Notifier(parent_); }
78
+ void OnError(grpc_error* error) override {
79
+ new Notifier(parent_, name_, error);
80
+ }
81
+ void OnResourceDoesNotExist() override { new Notifier(parent_, name_); }
77
82
 
78
83
  private:
79
84
  class Notifier {
80
85
  public:
81
- Notifier(RefCountedPtr<CdsLb> parent, XdsApi::CdsUpdate update);
82
- Notifier(RefCountedPtr<CdsLb> parent, grpc_error* error);
83
- explicit Notifier(RefCountedPtr<CdsLb> parent);
86
+ Notifier(RefCountedPtr<CdsLb> parent, std::string name,
87
+ XdsApi::CdsUpdate update);
88
+ Notifier(RefCountedPtr<CdsLb> parent, std::string name,
89
+ grpc_error* error);
90
+ explicit Notifier(RefCountedPtr<CdsLb> parent, std::string name);
84
91
 
85
92
  private:
86
93
  enum Type { kUpdate, kError, kDoesNotExist };
@@ -89,12 +96,22 @@ class CdsLb : public LoadBalancingPolicy {
89
96
  void RunInWorkSerializer(grpc_error* error);
90
97
 
91
98
  RefCountedPtr<CdsLb> parent_;
99
+ std::string name_;
92
100
  grpc_closure closure_;
93
101
  XdsApi::CdsUpdate update_;
94
102
  Type type_;
95
103
  };
96
104
 
97
105
  RefCountedPtr<CdsLb> parent_;
106
+ std::string name_;
107
+ };
108
+
109
+ struct WatcherState {
110
+ // Pointer to watcher, to be used when cancelling.
111
+ // Not owned, so do not dereference.
112
+ ClusterWatcher* watcher = nullptr;
113
+ // Most recent update obtained from this watcher.
114
+ absl::optional<XdsApi::CdsUpdate> update;
98
115
  };
99
116
 
100
117
  // Delegating helper to be passed to child policy.
@@ -117,9 +134,20 @@ class CdsLb : public LoadBalancingPolicy {
117
134
 
118
135
  void ShutdownLocked() override;
119
136
 
120
- void OnClusterChanged(XdsApi::CdsUpdate cluster_data);
121
- void OnError(grpc_error* error);
122
- void OnResourceDoesNotExist();
137
+ bool GenerateDiscoveryMechanismForCluster(
138
+ const std::string& name, Json::Array* discovery_mechanisms,
139
+ std::set<std::string>* clusters_needed);
140
+ void OnClusterChanged(const std::string& name,
141
+ XdsApi::CdsUpdate cluster_data);
142
+ void OnError(const std::string& name, grpc_error* error);
143
+ void OnResourceDoesNotExist(const std::string& name);
144
+
145
+ grpc_error* UpdateXdsCertificateProvider(
146
+ const std::string& cluster_name, const XdsApi::CdsUpdate& cluster_data);
147
+
148
+ void CancelClusterDataWatch(absl::string_view cluster_name,
149
+ XdsClient::ClusterWatcherInterface* watcher,
150
+ bool delay_unsubscription = false);
123
151
 
124
152
  void MaybeDestroyChildPolicyLocked();
125
153
 
@@ -130,9 +158,14 @@ class CdsLb : public LoadBalancingPolicy {
130
158
 
131
159
  // The xds client.
132
160
  RefCountedPtr<XdsClient> xds_client_;
133
- // A pointer to the cluster watcher, to be used when cancelling the watch.
134
- // Note that this is not owned, so this pointer must never be derefernced.
135
- ClusterWatcher* cluster_watcher_ = nullptr;
161
+
162
+ // Maps from cluster name to the state for that cluster.
163
+ // The root of the tree is config_->cluster().
164
+ std::map<std::string, WatcherState> watchers_;
165
+
166
+ RefCountedPtr<grpc_tls_certificate_provider> root_certificate_provider_;
167
+ RefCountedPtr<grpc_tls_certificate_provider> identity_certificate_provider_;
168
+ RefCountedPtr<XdsCertificateProvider> xds_certificate_provider_;
136
169
 
137
170
  // Child LB policy.
138
171
  OrphanablePtr<LoadBalancingPolicy> child_policy_;
@@ -146,21 +179,26 @@ class CdsLb : public LoadBalancingPolicy {
146
179
  //
147
180
 
148
181
  CdsLb::ClusterWatcher::Notifier::Notifier(RefCountedPtr<CdsLb> parent,
182
+ std::string name,
149
183
  XdsApi::CdsUpdate update)
150
- : parent_(std::move(parent)), update_(std::move(update)), type_(kUpdate) {
184
+ : parent_(std::move(parent)),
185
+ name_(std::move(name)),
186
+ update_(std::move(update)),
187
+ type_(kUpdate) {
151
188
  GRPC_CLOSURE_INIT(&closure_, &RunInExecCtx, this, nullptr);
152
189
  ExecCtx::Run(DEBUG_LOCATION, &closure_, GRPC_ERROR_NONE);
153
190
  }
154
191
 
155
192
  CdsLb::ClusterWatcher::Notifier::Notifier(RefCountedPtr<CdsLb> parent,
156
- grpc_error* error)
157
- : parent_(std::move(parent)), type_(kError) {
193
+ std::string name, grpc_error* error)
194
+ : parent_(std::move(parent)), name_(std::move(name)), type_(kError) {
158
195
  GRPC_CLOSURE_INIT(&closure_, &RunInExecCtx, this, nullptr);
159
196
  ExecCtx::Run(DEBUG_LOCATION, &closure_, error);
160
197
  }
161
198
 
162
- CdsLb::ClusterWatcher::Notifier::Notifier(RefCountedPtr<CdsLb> parent)
163
- : parent_(std::move(parent)), type_(kDoesNotExist) {
199
+ CdsLb::ClusterWatcher::Notifier::Notifier(RefCountedPtr<CdsLb> parent,
200
+ std::string name)
201
+ : parent_(std::move(parent)), name_(std::move(name)), type_(kDoesNotExist) {
164
202
  GRPC_CLOSURE_INIT(&closure_, &RunInExecCtx, this, nullptr);
165
203
  ExecCtx::Run(DEBUG_LOCATION, &closure_, GRPC_ERROR_NONE);
166
204
  }
@@ -176,13 +214,13 @@ void CdsLb::ClusterWatcher::Notifier::RunInExecCtx(void* arg,
176
214
  void CdsLb::ClusterWatcher::Notifier::RunInWorkSerializer(grpc_error* error) {
177
215
  switch (type_) {
178
216
  case kUpdate:
179
- parent_->OnClusterChanged(std::move(update_));
217
+ parent_->OnClusterChanged(name_, std::move(update_));
180
218
  break;
181
219
  case kError:
182
- parent_->OnError(error);
220
+ parent_->OnError(name_, error);
183
221
  break;
184
222
  case kDoesNotExist:
185
- parent_->OnResourceDoesNotExist();
223
+ parent_->OnResourceDoesNotExist(name_);
186
224
  break;
187
225
  };
188
226
  delete this;
@@ -252,13 +290,15 @@ void CdsLb::ShutdownLocked() {
252
290
  shutting_down_ = true;
253
291
  MaybeDestroyChildPolicyLocked();
254
292
  if (xds_client_ != nullptr) {
255
- if (cluster_watcher_ != nullptr) {
293
+ for (auto& watcher : watchers_) {
256
294
  if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
257
295
  gpr_log(GPR_INFO, "[cdslb %p] cancelling watch for cluster %s", this,
258
- config_->cluster().c_str());
296
+ watcher.first.c_str());
259
297
  }
260
- xds_client_->CancelClusterDataWatch(config_->cluster(), cluster_watcher_);
298
+ CancelClusterDataWatch(watcher.first, watcher.second.watcher,
299
+ /*delay_unsubscription=*/false);
261
300
  }
301
+ watchers_.clear();
262
302
  xds_client_.reset(DEBUG_LOCATION, "CdsLb");
263
303
  }
264
304
  grpc_channel_args_destroy(args_);
@@ -277,6 +317,10 @@ void CdsLb::ResetBackoffLocked() {
277
317
  if (child_policy_ != nullptr) child_policy_->ResetBackoffLocked();
278
318
  }
279
319
 
320
+ void CdsLb::ExitIdleLocked() {
321
+ if (child_policy_ != nullptr) child_policy_->ExitIdleLocked();
322
+ }
323
+
280
324
  void CdsLb::UpdateLocked(UpdateArgs args) {
281
325
  // Update config.
282
326
  auto old_config = std::move(config_);
@@ -292,110 +336,214 @@ void CdsLb::UpdateLocked(UpdateArgs args) {
292
336
  // If cluster name changed, cancel watcher and restart.
293
337
  if (old_config == nullptr || old_config->cluster() != config_->cluster()) {
294
338
  if (old_config != nullptr) {
295
- if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
296
- gpr_log(GPR_INFO, "[cdslb %p] cancelling watch for cluster %s", this,
297
- old_config->cluster().c_str());
339
+ for (auto& watcher : watchers_) {
340
+ if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
341
+ gpr_log(GPR_INFO, "[cdslb %p] cancelling watch for cluster %s", this,
342
+ watcher.first.c_str());
343
+ }
344
+ CancelClusterDataWatch(watcher.first, watcher.second.watcher,
345
+ /*delay_unsubscription=*/true);
298
346
  }
299
- xds_client_->CancelClusterDataWatch(old_config->cluster(),
300
- cluster_watcher_,
301
- /*delay_unsubscription=*/true);
302
- }
303
- if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
304
- gpr_log(GPR_INFO, "[cdslb %p] starting watch for cluster %s", this,
305
- config_->cluster().c_str());
347
+ watchers_.clear();
306
348
  }
307
- auto watcher = absl::make_unique<ClusterWatcher>(Ref());
308
- cluster_watcher_ = watcher.get();
349
+ auto watcher = absl::make_unique<ClusterWatcher>(Ref(), config_->cluster());
350
+ watchers_[config_->cluster()].watcher = watcher.get();
309
351
  xds_client_->WatchClusterData(config_->cluster(), std::move(watcher));
310
352
  }
311
353
  }
312
354
 
313
- void CdsLb::OnClusterChanged(XdsApi::CdsUpdate cluster_data) {
314
- if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
315
- gpr_log(GPR_INFO,
316
- "[cdslb %p] received CDS update from xds client %p: "
317
- "eds_service_name=%s lrs_load_reporting_server_name=%s "
318
- "max_concurrent_requests=%d",
319
- this, xds_client_.get(), cluster_data.eds_service_name.c_str(),
320
- cluster_data.lrs_load_reporting_server_name.has_value()
321
- ? cluster_data.lrs_load_reporting_server_name.value().c_str()
322
- : "(unset)",
323
- cluster_data.max_concurrent_requests);
355
+ // This method will attempt to generate one or multiple entries of discovery
356
+ // mechanism recursively:
357
+ // For cluster types EDS or LOGICAL_DNS, one discovery mechanism entry may be
358
+ // generated cluster name, type and other data from the CdsUpdate inserted into
359
+ // the entry and the entry appended to the array of entries.
360
+ // Note, discovery mechanism entry can be generated if an CdsUpdate is
361
+ // available; otherwise, just return false. For cluster type AGGREGATE,
362
+ // recursively call the method for each child cluster.
363
+ bool CdsLb::GenerateDiscoveryMechanismForCluster(
364
+ const std::string& name, Json::Array* discovery_mechanisms,
365
+ std::set<std::string>* clusters_needed) {
366
+ clusters_needed->insert(name);
367
+ auto& state = watchers_[name];
368
+ // Create a new watcher if needed.
369
+ if (state.watcher == nullptr) {
370
+ auto watcher = absl::make_unique<ClusterWatcher>(Ref(), name);
371
+ if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
372
+ gpr_log(GPR_INFO, "[cdslb %p] starting watch for cluster %s", this,
373
+ name.c_str());
374
+ }
375
+ state.watcher = watcher.get();
376
+ xds_client_->WatchClusterData(name, std::move(watcher));
377
+ return false;
324
378
  }
325
- // Construct config for child policy.
326
- Json::Object child_config = {
327
- {"clusterName", config_->cluster()},
328
- {"max_concurrent_requests", cluster_data.max_concurrent_requests},
329
- {"localityPickingPolicy",
330
- Json::Array{
331
- Json::Object{
332
- {"weighted_target_experimental",
333
- Json::Object{
334
- {"targets", Json::Object()},
335
- }},
336
- },
337
- }},
338
- {"endpointPickingPolicy",
339
- Json::Array{
340
- Json::Object{
341
- {"round_robin", Json::Object()},
342
- },
343
- }},
344
- };
345
- if (!cluster_data.eds_service_name.empty()) {
346
- child_config["edsServiceName"] = cluster_data.eds_service_name;
379
+ // Don't have the update we need yet.
380
+ if (!state.update.has_value()) return false;
381
+ // For AGGREGATE clusters, recursively expand to child clusters.
382
+ if (state.update->cluster_type == XdsApi::CdsUpdate::ClusterType::AGGREGATE) {
383
+ bool missing_cluster = false;
384
+ for (const std::string& child_name :
385
+ state.update->prioritized_cluster_names) {
386
+ if (!GenerateDiscoveryMechanismForCluster(
387
+ child_name, discovery_mechanisms, clusters_needed)) {
388
+ missing_cluster = true;
389
+ }
390
+ }
391
+ return !missing_cluster;
347
392
  }
348
- if (cluster_data.lrs_load_reporting_server_name.has_value()) {
349
- child_config["lrsLoadReportingServerName"] =
350
- cluster_data.lrs_load_reporting_server_name.value();
393
+ std::string type;
394
+ switch (state.update->cluster_type) {
395
+ case XdsApi::CdsUpdate::ClusterType::EDS:
396
+ type = "EDS";
397
+ break;
398
+ case XdsApi::CdsUpdate::ClusterType::LOGICAL_DNS:
399
+ type = "LOGICAL_DNS";
400
+ break;
401
+ default:
402
+ GPR_ASSERT(0);
403
+ break;
351
404
  }
352
- Json json = Json::Array{
353
- Json::Object{
354
- {"eds_experimental", std::move(child_config)},
355
- },
405
+ Json::Object mechanism = {
406
+ {"clusterName", name},
407
+ {"max_concurrent_requests", state.update->max_concurrent_requests},
408
+ {"type", std::move(type)},
356
409
  };
410
+ if (!state.update->eds_service_name.empty()) {
411
+ mechanism["edsServiceName"] = state.update->eds_service_name;
412
+ }
413
+ if (state.update->lrs_load_reporting_server_name.has_value()) {
414
+ mechanism["lrsLoadReportingServerName"] =
415
+ state.update->lrs_load_reporting_server_name.value();
416
+ }
417
+ discovery_mechanisms->emplace_back(std::move(mechanism));
418
+ return true;
419
+ }
420
+
421
+ void CdsLb::OnClusterChanged(const std::string& name,
422
+ XdsApi::CdsUpdate cluster_data) {
357
423
  if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
358
- std::string json_str = json.Dump(/*indent=*/1);
359
- gpr_log(GPR_INFO, "[cdslb %p] generated config for child policy: %s", this,
360
- json_str.c_str());
424
+ gpr_log(
425
+ GPR_INFO,
426
+ "[cdslb %p] received CDS update for cluster %s from xds client %p: %s",
427
+ this, name.c_str(), xds_client_.get(), cluster_data.ToString().c_str());
361
428
  }
429
+ // Store the update in the map if we are still interested in watching this
430
+ // cluster (i.e., it is not cancelled already).
431
+ // If we've already deleted this entry, then this is an update notification
432
+ // that was scheduled before the deletion, so we can just ignore it.
433
+ auto it = watchers_.find(name);
434
+ if (it == watchers_.end()) return;
435
+ it->second.update = cluster_data;
436
+ // Take care of integration with new certificate code.
362
437
  grpc_error* error = GRPC_ERROR_NONE;
363
- RefCountedPtr<LoadBalancingPolicy::Config> config =
364
- LoadBalancingPolicyRegistry::ParseLoadBalancingConfig(json, &error);
438
+ error = UpdateXdsCertificateProvider(name, it->second.update.value());
365
439
  if (error != GRPC_ERROR_NONE) {
366
- OnError(error);
367
- return;
440
+ return OnError(name, error);
368
441
  }
369
- // Create child policy if not already present.
370
- if (child_policy_ == nullptr) {
371
- LoadBalancingPolicy::Args args;
372
- args.work_serializer = work_serializer();
373
- args.args = args_;
374
- args.channel_control_helper = absl::make_unique<Helper>(Ref());
375
- child_policy_ = LoadBalancingPolicyRegistry::CreateLoadBalancingPolicy(
376
- config->name(), std::move(args));
377
- if (child_policy_ == nullptr) {
378
- OnError(GRPC_ERROR_CREATE_FROM_STATIC_STRING(
379
- "failed to create child policy"));
442
+ // Scan the map starting from the root cluster to generate the list of
443
+ // discovery mechanisms. If we don't have some of the data we need (i.e., we
444
+ // just started up and not all watchers have returned data yet), then don't
445
+ // update the child policy at all.
446
+ Json::Array discovery_mechanisms;
447
+ std::set<std::string> clusters_needed;
448
+ if (GenerateDiscoveryMechanismForCluster(
449
+ config_->cluster(), &discovery_mechanisms, &clusters_needed)) {
450
+ // Construct config for child policy.
451
+ Json::Object xds_lb_policy;
452
+ if (cluster_data.lb_policy == "RING_HASH") {
453
+ std::string hash_function;
454
+ switch (cluster_data.hash_function) {
455
+ case XdsApi::CdsUpdate::HashFunction::XX_HASH:
456
+ hash_function = "XX_HASH";
457
+ break;
458
+ case XdsApi::CdsUpdate::HashFunction::MURMUR_HASH_2:
459
+ hash_function = "MURMUR_HASH_2";
460
+ break;
461
+ default:
462
+ GPR_ASSERT(0);
463
+ break;
464
+ }
465
+ xds_lb_policy["RING_HASH"] = Json::Object{
466
+ {"min_ring_size", cluster_data.min_ring_size},
467
+ {"max_ring_size", cluster_data.max_ring_size},
468
+ {"hash_function", hash_function},
469
+ };
470
+ } else {
471
+ xds_lb_policy["ROUND_ROBIN"] = Json::Object();
472
+ }
473
+ Json::Object child_config = {
474
+ {"xdsLbPolicy",
475
+ Json::Array{
476
+ xds_lb_policy,
477
+ }},
478
+ {"discoveryMechanisms", std::move(discovery_mechanisms)},
479
+ };
480
+ Json json = Json::Array{
481
+ Json::Object{
482
+ {"xds_cluster_resolver_experimental", std::move(child_config)},
483
+ },
484
+ };
485
+ if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
486
+ std::string json_str = json.Dump(/*indent=*/1);
487
+ gpr_log(GPR_INFO, "[cdslb %p] generated config for child policy: %s",
488
+ this, json_str.c_str());
489
+ }
490
+ RefCountedPtr<LoadBalancingPolicy::Config> config =
491
+ LoadBalancingPolicyRegistry::ParseLoadBalancingConfig(json, &error);
492
+ if (error != GRPC_ERROR_NONE) {
493
+ OnError(name, error);
380
494
  return;
381
495
  }
382
- grpc_pollset_set_add_pollset_set(child_policy_->interested_parties(),
383
- interested_parties());
496
+ // Create child policy if not already present.
497
+ if (child_policy_ == nullptr) {
498
+ LoadBalancingPolicy::Args args;
499
+ args.work_serializer = work_serializer();
500
+ args.args = args_;
501
+ args.channel_control_helper = absl::make_unique<Helper>(Ref());
502
+ child_policy_ = LoadBalancingPolicyRegistry::CreateLoadBalancingPolicy(
503
+ config->name(), std::move(args));
504
+ if (child_policy_ == nullptr) {
505
+ OnError(name, GRPC_ERROR_CREATE_FROM_STATIC_STRING(
506
+ "failed to create child policy"));
507
+ return;
508
+ }
509
+ grpc_pollset_set_add_pollset_set(child_policy_->interested_parties(),
510
+ interested_parties());
511
+ if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
512
+ gpr_log(GPR_INFO, "[cdslb %p] created child policy %s (%p)", this,
513
+ config->name(), child_policy_.get());
514
+ }
515
+ }
516
+ // Update child policy.
517
+ UpdateArgs args;
518
+ args.config = std::move(config);
519
+ if (xds_certificate_provider_ != nullptr) {
520
+ grpc_arg arg_to_add = xds_certificate_provider_->MakeChannelArg();
521
+ args.args = grpc_channel_args_copy_and_add(args_, &arg_to_add, 1);
522
+ } else {
523
+ args.args = grpc_channel_args_copy(args_);
524
+ }
525
+ child_policy_->UpdateLocked(std::move(args));
526
+ }
527
+ // Remove entries in watchers_ for any clusters not in clusters_needed
528
+ for (auto it = watchers_.begin(); it != watchers_.end();) {
529
+ const std::string& cluster_name = it->first;
530
+ if (clusters_needed.find(cluster_name) != clusters_needed.end()) {
531
+ ++it;
532
+ continue;
533
+ }
384
534
  if (GRPC_TRACE_FLAG_ENABLED(grpc_cds_lb_trace)) {
385
- gpr_log(GPR_INFO, "[cdslb %p] created child policy %s (%p)", this,
386
- config->name(), child_policy_.get());
535
+ gpr_log(GPR_INFO, "[cdslb %p] cancelling watch for cluster %s", this,
536
+ cluster_name.c_str());
387
537
  }
538
+ CancelClusterDataWatch(cluster_name, it->second.watcher,
539
+ /*delay_unsubscription=*/false);
540
+ it = watchers_.erase(it);
388
541
  }
389
- // Update child policy.
390
- UpdateArgs args;
391
- args.config = std::move(config);
392
- args.args = grpc_channel_args_copy(args_);
393
- child_policy_->UpdateLocked(std::move(args));
394
542
  }
395
543
 
396
- void CdsLb::OnError(grpc_error* error) {
544
+ void CdsLb::OnError(const std::string& name, grpc_error* error) {
397
545
  gpr_log(GPR_ERROR, "[cdslb %p] xds error obtaining data for cluster %s: %s",
398
- this, config_->cluster().c_str(), grpc_error_string(error));
546
+ this, name.c_str(), grpc_error_string(error));
399
547
  // Go into TRANSIENT_FAILURE if we have not yet created the child
400
548
  // policy (i.e., we have not yet received data from xds). Otherwise,
401
549
  // we keep running with the data we had previously.
@@ -408,11 +556,11 @@ void CdsLb::OnError(grpc_error* error) {
408
556
  }
409
557
  }
410
558
 
411
- void CdsLb::OnResourceDoesNotExist() {
559
+ void CdsLb::OnResourceDoesNotExist(const std::string& name) {
412
560
  gpr_log(GPR_ERROR,
413
561
  "[cdslb %p] CDS resource for %s does not exist -- reporting "
414
562
  "TRANSIENT_FAILURE",
415
- this, config_->cluster().c_str());
563
+ this, name.c_str());
416
564
  grpc_error* error =
417
565
  grpc_error_set_int(GRPC_ERROR_CREATE_FROM_COPIED_STRING(
418
566
  absl::StrCat("CDS resource \"", config_->cluster(),
@@ -425,6 +573,118 @@ void CdsLb::OnResourceDoesNotExist() {
425
573
  MaybeDestroyChildPolicyLocked();
426
574
  }
427
575
 
576
+ grpc_error* CdsLb::UpdateXdsCertificateProvider(
577
+ const std::string& cluster_name, const XdsApi::CdsUpdate& cluster_data) {
578
+ // Early out if channel is not configured to use xds security.
579
+ grpc_channel_credentials* channel_credentials =
580
+ grpc_channel_credentials_find_in_args(args_);
581
+ if (channel_credentials == nullptr ||
582
+ channel_credentials->type() != kCredentialsTypeXds) {
583
+ xds_certificate_provider_ = nullptr;
584
+ return GRPC_ERROR_NONE;
585
+ }
586
+ if (xds_certificate_provider_ == nullptr) {
587
+ xds_certificate_provider_ = MakeRefCounted<XdsCertificateProvider>();
588
+ }
589
+ // Configure root cert.
590
+ absl::string_view root_provider_instance_name =
591
+ cluster_data.common_tls_context.combined_validation_context
592
+ .validation_context_certificate_provider_instance.instance_name;
593
+ absl::string_view root_provider_cert_name =
594
+ cluster_data.common_tls_context.combined_validation_context
595
+ .validation_context_certificate_provider_instance.certificate_name;
596
+ RefCountedPtr<XdsCertificateProvider> new_root_provider;
597
+ if (!root_provider_instance_name.empty()) {
598
+ new_root_provider =
599
+ xds_client_->certificate_provider_store()
600
+ .CreateOrGetCertificateProvider(root_provider_instance_name);
601
+ if (new_root_provider == nullptr) {
602
+ return GRPC_ERROR_CREATE_FROM_COPIED_STRING(
603
+ absl::StrCat("Certificate provider instance name: \"",
604
+ root_provider_instance_name, "\" not recognized.")
605
+ .c_str());
606
+ }
607
+ }
608
+ if (root_certificate_provider_ != new_root_provider) {
609
+ if (root_certificate_provider_ != nullptr &&
610
+ root_certificate_provider_->interested_parties() != nullptr) {
611
+ grpc_pollset_set_del_pollset_set(
612
+ interested_parties(),
613
+ root_certificate_provider_->interested_parties());
614
+ }
615
+ if (new_root_provider != nullptr &&
616
+ new_root_provider->interested_parties() != nullptr) {
617
+ grpc_pollset_set_add_pollset_set(interested_parties(),
618
+ new_root_provider->interested_parties());
619
+ }
620
+ root_certificate_provider_ = std::move(new_root_provider);
621
+ }
622
+ xds_certificate_provider_->UpdateRootCertNameAndDistributor(
623
+ cluster_name, root_provider_cert_name,
624
+ root_certificate_provider_ == nullptr
625
+ ? nullptr
626
+ : root_certificate_provider_->distributor());
627
+ // Configure identity cert.
628
+ absl::string_view identity_provider_instance_name =
629
+ cluster_data.common_tls_context
630
+ .tls_certificate_certificate_provider_instance.instance_name;
631
+ absl::string_view identity_provider_cert_name =
632
+ cluster_data.common_tls_context
633
+ .tls_certificate_certificate_provider_instance.certificate_name;
634
+ RefCountedPtr<XdsCertificateProvider> new_identity_provider;
635
+ if (!identity_provider_instance_name.empty()) {
636
+ new_identity_provider =
637
+ xds_client_->certificate_provider_store()
638
+ .CreateOrGetCertificateProvider(identity_provider_instance_name);
639
+ if (new_identity_provider == nullptr) {
640
+ return GRPC_ERROR_CREATE_FROM_COPIED_STRING(
641
+ absl::StrCat("Certificate provider instance name: \"",
642
+ identity_provider_instance_name, "\" not recognized.")
643
+ .c_str());
644
+ }
645
+ }
646
+ if (identity_certificate_provider_ != new_identity_provider) {
647
+ if (identity_certificate_provider_ != nullptr &&
648
+ identity_certificate_provider_->interested_parties() != nullptr) {
649
+ grpc_pollset_set_del_pollset_set(
650
+ interested_parties(),
651
+ identity_certificate_provider_->interested_parties());
652
+ }
653
+ if (new_identity_provider != nullptr &&
654
+ new_identity_provider->interested_parties() != nullptr) {
655
+ grpc_pollset_set_add_pollset_set(
656
+ interested_parties(), new_identity_provider->interested_parties());
657
+ }
658
+ identity_certificate_provider_ = std::move(new_identity_provider);
659
+ }
660
+ xds_certificate_provider_->UpdateIdentityCertNameAndDistributor(
661
+ cluster_name, identity_provider_cert_name,
662
+ identity_certificate_provider_ == nullptr
663
+ ? nullptr
664
+ : identity_certificate_provider_->distributor());
665
+ // Configure SAN matchers.
666
+ const std::vector<StringMatcher>& match_subject_alt_names =
667
+ cluster_data.common_tls_context.combined_validation_context
668
+ .default_validation_context.match_subject_alt_names;
669
+ xds_certificate_provider_->UpdateSubjectAlternativeNameMatchers(
670
+ cluster_name, match_subject_alt_names);
671
+ return GRPC_ERROR_NONE;
672
+ }
673
+
674
+ void CdsLb::CancelClusterDataWatch(absl::string_view cluster_name,
675
+ XdsClient::ClusterWatcherInterface* watcher,
676
+ bool delay_unsubscription) {
677
+ if (xds_certificate_provider_ != nullptr) {
678
+ std::string name(cluster_name);
679
+ xds_certificate_provider_->UpdateRootCertNameAndDistributor(name, "",
680
+ nullptr);
681
+ xds_certificate_provider_->UpdateIdentityCertNameAndDistributor(name, "",
682
+ nullptr);
683
+ xds_certificate_provider_->UpdateSubjectAlternativeNameMatchers(name, {});
684
+ }
685
+ xds_client_->CancelClusterDataWatch(cluster_name, watcher,
686
+ delay_unsubscription);
687
+ }
428
688
  //
429
689
  // factory
430
690
  //
@@ -459,6 +719,7 @@ class CdsLbFactory : public LoadBalancingPolicyFactory {
459
719
  return nullptr;
460
720
  }
461
721
  std::vector<grpc_error*> error_list;
722
+ // cluster name.
462
723
  std::string cluster;
463
724
  auto it = json.object_value().find("cluster");
464
725
  if (it == json.object_value().end()) {