grpc 1.40.0.pre1 → 1.41.1

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 (900) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +29 -37
  3. data/etc/roots.pem +335 -326
  4. data/include/grpc/byte_buffer.h +1 -1
  5. data/include/grpc/byte_buffer_reader.h +1 -1
  6. data/include/grpc/event_engine/endpoint_config.h +6 -11
  7. data/include/grpc/event_engine/event_engine.h +63 -58
  8. data/include/grpc/event_engine/port.h +1 -3
  9. data/include/grpc/event_engine/slice_allocator.h +6 -1
  10. data/include/grpc/fork.h +1 -1
  11. data/include/grpc/grpc.h +10 -4
  12. data/include/grpc/grpc_posix.h +5 -2
  13. data/include/grpc/impl/codegen/atm.h +5 -3
  14. data/include/grpc/impl/codegen/atm_gcc_atomic.h +2 -0
  15. data/include/grpc/impl/codegen/atm_gcc_sync.h +2 -0
  16. data/include/grpc/impl/codegen/atm_windows.h +2 -0
  17. data/include/grpc/impl/codegen/byte_buffer.h +2 -0
  18. data/include/grpc/impl/codegen/byte_buffer_reader.h +2 -0
  19. data/include/grpc/impl/codegen/compression_types.h +2 -0
  20. data/include/grpc/impl/codegen/connectivity_state.h +2 -0
  21. data/include/grpc/impl/codegen/fork.h +2 -0
  22. data/include/grpc/impl/codegen/gpr_slice.h +2 -0
  23. data/include/grpc/impl/codegen/gpr_types.h +2 -0
  24. data/include/grpc/impl/codegen/grpc_types.h +4 -5
  25. data/include/grpc/impl/codegen/log.h +2 -0
  26. data/include/grpc/impl/codegen/port_platform.h +26 -22
  27. data/include/grpc/impl/codegen/propagation_bits.h +2 -0
  28. data/include/grpc/impl/codegen/slice.h +2 -0
  29. data/include/grpc/impl/codegen/status.h +2 -0
  30. data/include/grpc/impl/codegen/sync.h +8 -5
  31. data/include/grpc/impl/codegen/sync_abseil.h +2 -0
  32. data/include/grpc/impl/codegen/sync_custom.h +2 -0
  33. data/include/grpc/impl/codegen/sync_generic.h +3 -0
  34. data/include/grpc/impl/codegen/sync_posix.h +4 -2
  35. data/include/grpc/impl/codegen/sync_windows.h +2 -0
  36. data/include/grpc/slice.h +1 -1
  37. data/include/grpc/status.h +1 -1
  38. data/include/grpc/support/atm.h +1 -1
  39. data/include/grpc/support/atm_gcc_atomic.h +1 -1
  40. data/include/grpc/support/atm_gcc_sync.h +1 -1
  41. data/include/grpc/support/atm_windows.h +1 -1
  42. data/include/grpc/support/log.h +1 -1
  43. data/include/grpc/support/port_platform.h +1 -1
  44. data/include/grpc/support/sync.h +1 -1
  45. data/include/grpc/support/sync_abseil.h +1 -1
  46. data/include/grpc/support/sync_custom.h +1 -1
  47. data/include/grpc/support/sync_generic.h +1 -1
  48. data/include/grpc/support/sync_posix.h +1 -1
  49. data/include/grpc/support/sync_windows.h +1 -1
  50. data/include/grpc/support/time.h +2 -2
  51. data/src/core/ext/filters/census/grpc_context.cc +1 -0
  52. data/src/core/ext/filters/client_channel/backend_metric.cc +0 -1
  53. data/src/core/ext/filters/client_channel/backup_poller.h +1 -0
  54. data/src/core/ext/filters/client_channel/channel_connectivity.cc +1 -2
  55. data/src/core/ext/filters/client_channel/client_channel.cc +24 -52
  56. data/src/core/ext/filters/client_channel/client_channel.h +3 -3
  57. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +6 -5
  58. data/src/core/ext/filters/client_channel/client_channel_channelz.h +1 -1
  59. data/src/core/ext/filters/client_channel/client_channel_factory.cc +1 -0
  60. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +8 -1
  61. data/src/core/ext/filters/client_channel/config_selector.cc +1 -0
  62. data/src/core/ext/filters/client_channel/health/health_check_client.cc +7 -6
  63. data/src/core/ext/filters/client_channel/health/health_check_client.h +4 -3
  64. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +8 -7
  65. data/src/core/ext/filters/client_channel/http_connect_handshaker.h +10 -2
  66. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +2 -2
  67. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +2 -8
  68. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -2
  69. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +2 -2
  70. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +2 -2
  71. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +2 -1
  72. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +14 -23
  73. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +1 -0
  74. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +2 -2
  75. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +2 -8
  76. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +15 -18
  77. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +10 -7
  78. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +2 -8
  79. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +2 -3
  80. data/src/core/ext/filters/client_channel/lb_policy.h +11 -44
  81. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +4 -7
  82. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +2 -10
  83. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +1 -0
  84. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +4 -3
  85. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +6 -5
  86. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +14 -19
  87. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +1 -0
  88. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +2 -2
  89. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +5 -5
  90. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +5 -8
  91. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +2 -3
  92. data/src/core/ext/filters/client_channel/retry_filter.cc +16 -3
  93. data/src/core/ext/filters/client_idle/client_idle_filter.cc +36 -30
  94. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +8 -6
  95. data/src/core/ext/filters/fault_injection/service_config_parser.cc +6 -13
  96. data/src/core/ext/filters/http/client/http_client_filter.cc +3 -2
  97. data/src/core/ext/filters/http/client_authority_filter.cc +2 -1
  98. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +2 -1
  99. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +7 -8
  100. data/src/core/ext/filters/http/server/http_server_filter.cc +5 -3
  101. data/src/core/ext/filters/message_size/message_size_filter.cc +9 -13
  102. data/src/core/ext/transport/chttp2/alpn/alpn.cc +2 -1
  103. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +29 -12
  104. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +2 -0
  105. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +2 -3
  106. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +10 -6
  107. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +2 -3
  108. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +60 -37
  109. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +0 -1
  110. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +12 -6
  111. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +5 -9
  112. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +3 -1
  113. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -1
  114. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +1 -0
  115. data/src/core/ext/transport/chttp2/transport/chttp2_slice_allocator.cc +4 -3
  116. data/src/core/ext/transport/chttp2/transport/chttp2_slice_allocator.h +2 -2
  117. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +24 -30
  118. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +4 -1
  119. data/src/core/ext/transport/chttp2/transport/context_list.h +1 -2
  120. data/src/core/ext/transport/chttp2/transport/flow_control.cc +39 -23
  121. data/src/core/ext/transport/chttp2/transport/flow_control.h +9 -3
  122. data/src/core/ext/transport/chttp2/transport/frame_data.cc +7 -7
  123. data/src/core/ext/transport/chttp2/transport/frame_data.h +1 -0
  124. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +4 -3
  125. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +1 -0
  126. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -4
  127. data/src/core/ext/transport/chttp2/transport/frame_ping.h +1 -0
  128. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +3 -5
  129. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +1 -0
  130. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +36 -5
  131. data/src/core/ext/transport/chttp2/transport/frame_settings.h +1 -0
  132. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +12 -7
  133. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +1 -0
  134. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +41 -0
  135. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +272 -666
  136. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +236 -70
  137. data/src/core/ext/transport/chttp2/transport/hpack_encoder_index.h +107 -0
  138. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +86 -0
  139. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +69 -0
  140. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +776 -1037
  141. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +48 -169
  142. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +159 -0
  143. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +130 -0
  144. data/src/core/ext/transport/chttp2/transport/hpack_utils.cc +46 -0
  145. data/src/core/ext/transport/chttp2/transport/hpack_utils.h +30 -0
  146. data/src/core/ext/transport/chttp2/transport/incoming_metadata.cc +2 -2
  147. data/src/core/ext/transport/chttp2/transport/internal.h +2 -2
  148. data/src/core/ext/transport/chttp2/transport/parsing.cc +20 -30
  149. data/src/core/ext/transport/chttp2/transport/popularity_count.h +60 -0
  150. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +2 -2
  151. data/src/core/ext/transport/chttp2/transport/varint.cc +7 -3
  152. data/src/core/ext/transport/chttp2/transport/varint.h +39 -28
  153. data/src/core/ext/transport/chttp2/transport/writing.cc +32 -28
  154. data/src/core/ext/transport/inproc/inproc_transport.cc +6 -4
  155. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +96 -96
  156. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +221 -89
  157. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +1 -1
  158. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +1 -1
  159. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +3 -3
  160. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +11 -5
  161. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +48 -48
  162. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +151 -61
  163. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +99 -99
  164. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +171 -69
  165. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +15 -15
  166. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +31 -13
  167. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +126 -127
  168. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +229 -101
  169. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +4 -4
  170. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +11 -5
  171. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +23 -23
  172. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +11 -5
  173. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +28 -28
  174. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +71 -29
  175. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +4 -4
  176. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +11 -5
  177. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +82 -82
  178. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +201 -81
  179. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +24 -24
  180. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +51 -21
  181. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +3 -3
  182. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +11 -5
  183. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +9 -9
  184. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +21 -9
  185. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +62 -62
  186. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +131 -53
  187. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +51 -51
  188. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +81 -33
  189. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +5 -5
  190. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +11 -5
  191. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +62 -62
  192. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +141 -57
  193. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +3 -3
  194. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +11 -5
  195. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +7 -7
  196. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +21 -9
  197. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +8 -8
  198. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +11 -5
  199. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +8 -8
  200. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +11 -5
  201. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +4 -4
  202. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +11 -5
  203. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +16 -16
  204. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +31 -13
  205. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +57 -22
  206. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +174 -17
  207. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +32 -32
  208. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +51 -21
  209. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +3 -3
  210. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +11 -5
  211. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +37 -37
  212. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +61 -25
  213. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +40 -40
  214. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +71 -29
  215. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +9 -9
  216. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +11 -5
  217. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +5 -5
  218. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +21 -9
  219. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +30 -30
  220. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +81 -33
  221. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +41 -29
  222. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +141 -43
  223. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +46 -43
  224. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +88 -29
  225. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +18 -18
  226. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +31 -13
  227. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +281 -277
  228. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +569 -248
  229. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +10 -10
  230. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +31 -13
  231. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +6 -6
  232. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +21 -9
  233. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +3 -3
  234. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +11 -5
  235. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +13 -13
  236. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +51 -21
  237. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +23 -23
  238. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +31 -13
  239. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +9 -9
  240. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +11 -5
  241. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +115 -116
  242. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +191 -77
  243. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +1 -1
  244. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +1 -1
  245. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +46 -32
  246. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +118 -34
  247. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +12 -12
  248. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +31 -13
  249. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +44 -42
  250. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +108 -55
  251. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.c +2 -2
  252. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +11 -5
  253. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +2 -2
  254. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +11 -5
  255. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +42 -42
  256. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +61 -25
  257. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.c +2 -2
  258. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +11 -5
  259. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.c +2 -2
  260. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +11 -5
  261. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +9 -9
  262. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +21 -9
  263. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.c +2 -2
  264. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +11 -5
  265. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.c +2 -2
  266. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +11 -5
  267. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +28 -28
  268. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +51 -21
  269. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +8 -8
  270. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +41 -17
  271. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +9 -8
  272. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +25 -9
  273. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +4 -4
  274. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +11 -5
  275. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +4 -4
  276. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +11 -5
  277. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +3 -3
  278. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +11 -5
  279. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +9 -9
  280. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +31 -13
  281. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +10 -10
  282. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +21 -9
  283. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +6 -6
  284. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +21 -9
  285. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +11 -11
  286. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +31 -13
  287. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +15 -15
  288. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +71 -29
  289. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +19 -19
  290. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +51 -21
  291. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +1 -1
  292. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +1 -1
  293. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +6 -6
  294. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +21 -9
  295. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +10 -10
  296. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +31 -13
  297. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +5 -5
  298. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +11 -5
  299. data/src/core/ext/upb-generated/google/api/annotations.upb.c +1 -1
  300. data/src/core/ext/upb-generated/google/api/annotations.upb.h +1 -1
  301. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +58 -58
  302. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +111 -45
  303. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +68 -68
  304. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +121 -49
  305. data/src/core/ext/upb-generated/google/api/http.upb.c +18 -18
  306. data/src/core/ext/upb-generated/google/api/http.upb.h +31 -13
  307. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +4 -4
  308. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +11 -5
  309. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +153 -153
  310. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +271 -109
  311. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +4 -4
  312. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +11 -5
  313. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +2 -2
  314. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +11 -5
  315. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +15 -15
  316. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +31 -13
  317. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +4 -4
  318. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +11 -5
  319. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +19 -19
  320. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +91 -37
  321. data/src/core/ext/upb-generated/google/rpc/status.upb.c +5 -5
  322. data/src/core/ext/upb-generated/google/rpc/status.upb.h +11 -5
  323. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +12 -12
  324. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +11 -5
  325. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +60 -60
  326. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +101 -41
  327. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +7 -7
  328. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +21 -9
  329. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +5 -5
  330. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +21 -9
  331. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +31 -31
  332. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +91 -37
  333. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +8 -8
  334. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +31 -13
  335. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +4 -4
  336. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +11 -5
  337. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +1 -1
  338. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +1 -1
  339. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +4 -4
  340. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +11 -5
  341. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +3 -3
  342. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +11 -5
  343. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.c +13 -13
  344. data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.h +11 -5
  345. data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.c +4 -4
  346. data/src/core/ext/upb-generated/udpa/type/v1/typed_struct.upb.h +11 -5
  347. data/src/core/ext/upb-generated/validate/validate.upb.c +220 -220
  348. data/src/core/ext/upb-generated/validate/validate.upb.h +231 -93
  349. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +3 -3
  350. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +11 -5
  351. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +8 -8
  352. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +21 -9
  353. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +6 -6
  354. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +11 -5
  355. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +5 -5
  356. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +11 -5
  357. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +11 -11
  358. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +21 -9
  359. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +6 -6
  360. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +11 -5
  361. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +384 -382
  362. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +94 -63
  363. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +10 -0
  364. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +30 -19
  365. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +5 -0
  366. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +791 -780
  367. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +96 -100
  368. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +133 -115
  369. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -0
  370. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +178 -173
  371. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +14 -13
  372. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +103 -103
  373. data/src/core/ext/xds/certificate_provider_registry.cc +2 -2
  374. data/src/core/ext/xds/xds_api.cc +853 -990
  375. data/src/core/ext/xds/xds_api.h +16 -33
  376. data/src/core/ext/xds/xds_bootstrap.cc +27 -52
  377. data/src/core/ext/xds/xds_client.cc +69 -30
  378. data/src/core/ext/xds/xds_client_stats.cc +16 -15
  379. data/src/core/ext/xds/xds_client_stats.h +6 -6
  380. data/src/core/ext/xds/xds_http_fault_filter.cc +4 -3
  381. data/src/core/ext/xds/xds_http_fault_filter.h +3 -2
  382. data/src/core/ext/xds/xds_http_filters.cc +1 -0
  383. data/src/core/ext/xds/xds_server_config_fetcher.cc +10 -10
  384. data/src/core/lib/address_utils/parse_address.cc +4 -8
  385. data/src/core/lib/address_utils/sockaddr_utils.cc +2 -2
  386. data/src/core/lib/channel/channel_args.cc +2 -1
  387. data/src/core/lib/channel/channel_stack.cc +5 -3
  388. data/src/core/lib/channel/channel_stack_builder.cc +1 -11
  389. data/src/core/lib/channel/channel_stack_builder.h +0 -8
  390. data/src/core/lib/channel/channel_trace.cc +4 -3
  391. data/src/core/lib/channel/channel_trace.h +1 -0
  392. data/src/core/lib/channel/channelz.cc +40 -36
  393. data/src/core/lib/channel/channelz.h +27 -27
  394. data/src/core/lib/channel/channelz_registry.cc +7 -6
  395. data/src/core/lib/channel/connected_channel.cc +1 -0
  396. data/src/core/lib/channel/handshaker.cc +2 -1
  397. data/src/core/lib/channel/handshaker.h +1 -2
  398. data/src/core/lib/channel/handshaker_factory.h +10 -2
  399. data/src/core/lib/channel/handshaker_registry.cc +15 -70
  400. data/src/core/lib/channel/handshaker_registry.h +29 -12
  401. data/src/core/lib/channel/status_util.h +2 -2
  402. data/src/core/lib/compression/algorithm_metadata.h +1 -0
  403. data/src/core/lib/compression/compression_args.cc +2 -1
  404. data/src/core/lib/compression/compression_internal.cc +2 -4
  405. data/src/core/lib/compression/message_compress.cc +2 -2
  406. data/src/core/lib/compression/stream_compression.cc +2 -1
  407. data/src/core/lib/compression/stream_compression.h +2 -1
  408. data/src/core/lib/compression/stream_compression_gzip.cc +2 -1
  409. data/src/core/lib/compression/stream_compression_identity.cc +2 -1
  410. data/src/core/lib/config/core_configuration.cc +54 -0
  411. data/src/core/lib/config/core_configuration.h +108 -0
  412. data/src/core/lib/debug/stats.h +1 -0
  413. data/src/core/lib/debug/stats_data.cc +2 -1
  414. data/src/core/lib/debug/stats_data.h +1 -0
  415. data/src/core/lib/debug/trace.cc +1 -0
  416. data/src/core/lib/debug/trace.h +2 -1
  417. data/src/core/lib/event_engine/endpoint_config.cc +0 -1
  418. data/src/core/lib/event_engine/event_engine.cc +3 -3
  419. data/src/core/lib/event_engine/sockaddr.cc +3 -3
  420. data/src/core/lib/gpr/alloc.cc +4 -3
  421. data/src/core/lib/gpr/env_linux.cc +1 -2
  422. data/src/core/lib/gpr/env_posix.cc +2 -3
  423. data/src/core/lib/gpr/log.cc +3 -3
  424. data/src/core/lib/gpr/log_android.cc +3 -2
  425. data/src/core/lib/gpr/log_linux.cc +7 -4
  426. data/src/core/lib/gpr/log_posix.cc +6 -3
  427. data/src/core/lib/gpr/string.h +2 -2
  428. data/src/core/lib/gpr/sync.cc +2 -2
  429. data/src/core/lib/gpr/sync_abseil.cc +7 -6
  430. data/src/core/lib/gpr/sync_posix.cc +3 -3
  431. data/src/core/lib/gpr/time.cc +3 -2
  432. data/src/core/lib/gpr/time_windows.cc +3 -2
  433. data/src/core/lib/gpr/tls.h +120 -41
  434. data/src/core/lib/gpr/tmpfile_posix.cc +1 -2
  435. data/src/core/lib/gprpp/arena.cc +2 -1
  436. data/src/core/lib/gprpp/arena.h +5 -5
  437. data/src/core/lib/gprpp/atomic_utils.h +47 -0
  438. data/src/core/lib/gprpp/bitset.h +166 -0
  439. data/src/core/lib/gprpp/construct_destruct.h +39 -0
  440. data/src/core/lib/gprpp/dual_ref_counted.h +25 -26
  441. data/src/core/lib/gprpp/fork.cc +14 -12
  442. data/src/core/lib/gprpp/fork.h +4 -4
  443. data/src/core/lib/gprpp/global_config.h +1 -2
  444. data/src/core/lib/gprpp/global_config_env.cc +7 -7
  445. data/src/core/lib/gprpp/global_config_generic.h +2 -2
  446. data/src/core/lib/gprpp/manual_constructor.h +8 -5
  447. data/src/core/lib/gprpp/match.h +73 -0
  448. data/src/core/lib/gprpp/memory.h +3 -3
  449. data/src/core/lib/gprpp/mpscq.cc +7 -7
  450. data/src/core/lib/gprpp/mpscq.h +6 -5
  451. data/src/core/lib/gprpp/orphanable.h +3 -3
  452. data/src/core/lib/gprpp/overload.h +59 -0
  453. data/src/core/lib/gprpp/ref_counted.h +18 -18
  454. data/src/core/lib/gprpp/status_helper.cc +4 -4
  455. data/src/core/lib/gprpp/sync.h +3 -1
  456. data/src/core/lib/gprpp/thd_posix.cc +5 -5
  457. data/src/core/lib/gprpp/thd_windows.cc +4 -11
  458. data/src/core/lib/gprpp/time_util.cc +2 -2
  459. data/src/core/lib/gprpp/time_util.h +2 -2
  460. data/src/core/lib/http/format_request.cc +1 -0
  461. data/src/core/lib/http/format_request.h +1 -0
  462. data/src/core/lib/http/httpcli.cc +9 -9
  463. data/src/core/lib/http/httpcli.h +3 -0
  464. data/src/core/lib/http/httpcli_security_connector.cc +5 -8
  465. data/src/core/lib/http/parser.h +1 -0
  466. data/src/core/lib/iomgr/buffer_list.cc +2 -1
  467. data/src/core/lib/iomgr/buffer_list.h +1 -2
  468. data/src/core/lib/iomgr/call_combiner.cc +1 -0
  469. data/src/core/lib/iomgr/cfstream_handle.cc +1 -1
  470. data/src/core/lib/iomgr/combiner.cc +3 -2
  471. data/src/core/lib/iomgr/combiner.h +1 -0
  472. data/src/core/lib/iomgr/dualstack_socket_posix.cc +1 -0
  473. data/src/core/lib/iomgr/endpoint.cc +0 -4
  474. data/src/core/lib/iomgr/endpoint.h +1 -3
  475. data/src/core/lib/iomgr/endpoint_cfstream.cc +9 -20
  476. data/src/core/lib/iomgr/endpoint_cfstream.h +1 -1
  477. data/src/core/lib/iomgr/endpoint_pair.h +1 -0
  478. data/src/core/lib/iomgr/endpoint_pair_event_engine.cc +1 -2
  479. data/src/core/lib/iomgr/endpoint_pair_posix.cc +15 -11
  480. data/src/core/lib/iomgr/endpoint_pair_windows.cc +17 -9
  481. data/src/core/lib/iomgr/error.h +23 -9
  482. data/src/core/lib/iomgr/error_cfstream.cc +2 -2
  483. data/src/core/lib/iomgr/error_internal.h +1 -0
  484. data/src/core/lib/iomgr/ev_epoll1_linux.cc +14 -22
  485. data/src/core/lib/iomgr/ev_epollex_linux.cc +15 -22
  486. data/src/core/lib/iomgr/ev_poll_posix.cc +13 -25
  487. data/src/core/lib/iomgr/ev_posix.cc +1 -2
  488. data/src/core/lib/iomgr/event_engine/endpoint.cc +3 -22
  489. data/src/core/lib/iomgr/event_engine/endpoint.h +1 -2
  490. data/src/core/lib/iomgr/event_engine/iomgr.cc +17 -18
  491. data/src/core/lib/iomgr/event_engine/iomgr.h +20 -2
  492. data/src/core/lib/iomgr/event_engine/resolver.cc +2 -1
  493. data/src/core/lib/iomgr/event_engine/tcp.cc +53 -24
  494. data/src/core/lib/iomgr/exec_ctx.cc +3 -4
  495. data/src/core/lib/iomgr/exec_ctx.h +11 -19
  496. data/src/core/lib/iomgr/executor/mpmcqueue.cc +10 -9
  497. data/src/core/lib/iomgr/executor/mpmcqueue.h +4 -3
  498. data/src/core/lib/iomgr/executor/threadpool.cc +2 -2
  499. data/src/core/lib/iomgr/executor/threadpool.h +2 -1
  500. data/src/core/lib/iomgr/executor.cc +5 -6
  501. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +2 -2
  502. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +2 -2
  503. data/src/core/lib/iomgr/internal_errqueue.cc +3 -2
  504. data/src/core/lib/iomgr/iocp_windows.cc +1 -0
  505. data/src/core/lib/iomgr/iomgr.h +2 -2
  506. data/src/core/lib/iomgr/iomgr_custom.cc +2 -2
  507. data/src/core/lib/iomgr/iomgr_custom.h +2 -2
  508. data/src/core/lib/iomgr/iomgr_internal.cc +2 -1
  509. data/src/core/lib/iomgr/iomgr_windows.cc +1 -2
  510. data/src/core/lib/iomgr/is_epollexclusive_available.cc +4 -4
  511. data/src/core/lib/iomgr/polling_entity.cc +2 -2
  512. data/src/core/lib/iomgr/pollset_custom.cc +3 -4
  513. data/src/core/lib/iomgr/pollset_custom.h +2 -2
  514. data/src/core/lib/iomgr/pollset_set_custom.cc +1 -2
  515. data/src/core/lib/iomgr/pollset_set_windows.cc +1 -0
  516. data/src/core/lib/iomgr/port.h +0 -5
  517. data/src/core/lib/iomgr/python_util.h +1 -0
  518. data/src/core/lib/iomgr/resolve_address.cc +2 -1
  519. data/src/core/lib/iomgr/resolve_address.h +0 -4
  520. data/src/core/lib/iomgr/resolve_address_custom.cc +4 -4
  521. data/src/core/lib/iomgr/resolve_address_custom.h +0 -1
  522. data/src/core/lib/iomgr/resolve_address_posix.cc +2 -4
  523. data/src/core/lib/iomgr/resolve_address_windows.cc +6 -8
  524. data/src/core/lib/iomgr/resource_quota.cc +127 -42
  525. data/src/core/lib/iomgr/resource_quota.h +66 -17
  526. data/src/core/lib/iomgr/sockaddr.h +1 -1
  527. data/src/core/lib/iomgr/socket_factory_posix.cc +3 -3
  528. data/src/core/lib/iomgr/socket_factory_posix.h +1 -0
  529. data/src/core/lib/iomgr/socket_mutator.h +2 -2
  530. data/src/core/lib/iomgr/socket_utils_common_posix.cc +3 -3
  531. data/src/core/lib/iomgr/socket_utils_linux.cc +4 -4
  532. data/src/core/lib/iomgr/socket_utils_posix.cc +2 -2
  533. data/src/core/lib/iomgr/socket_utils_posix.h +2 -2
  534. data/src/core/lib/iomgr/socket_utils_windows.cc +2 -2
  535. data/src/core/lib/iomgr/tcp_client.cc +4 -2
  536. data/src/core/lib/iomgr/tcp_client.h +4 -0
  537. data/src/core/lib/iomgr/tcp_client_cfstream.cc +9 -19
  538. data/src/core/lib/iomgr/tcp_client_custom.cc +9 -17
  539. data/src/core/lib/iomgr/tcp_client_posix.cc +24 -9
  540. data/src/core/lib/iomgr/tcp_client_posix.h +5 -2
  541. data/src/core/lib/iomgr/tcp_client_windows.cc +14 -6
  542. data/src/core/lib/iomgr/tcp_custom.cc +11 -23
  543. data/src/core/lib/iomgr/tcp_custom.h +2 -1
  544. data/src/core/lib/iomgr/tcp_posix.cc +29 -59
  545. data/src/core/lib/iomgr/tcp_posix.h +11 -12
  546. data/src/core/lib/iomgr/tcp_server.cc +6 -4
  547. data/src/core/lib/iomgr/tcp_server.h +12 -9
  548. data/src/core/lib/iomgr/tcp_server_custom.cc +15 -33
  549. data/src/core/lib/iomgr/tcp_server_posix.cc +20 -13
  550. data/src/core/lib/iomgr/tcp_server_utils_posix.h +3 -0
  551. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +1 -2
  552. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +3 -4
  553. data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +4 -4
  554. data/src/core/lib/iomgr/tcp_server_windows.cc +13 -9
  555. data/src/core/lib/iomgr/tcp_windows.cc +6 -25
  556. data/src/core/lib/iomgr/tcp_windows.h +2 -1
  557. data/src/core/lib/iomgr/timer.cc +1 -0
  558. data/src/core/lib/iomgr/timer.h +1 -2
  559. data/src/core/lib/iomgr/timer_custom.cc +2 -2
  560. data/src/core/lib/iomgr/timer_generic.cc +8 -38
  561. data/src/core/lib/iomgr/timer_generic.h +1 -0
  562. data/src/core/lib/iomgr/timer_heap.cc +1 -2
  563. data/src/core/lib/iomgr/udp_server.cc +1 -2
  564. data/src/core/lib/iomgr/unix_sockets_posix.cc +3 -5
  565. data/src/core/lib/iomgr/unix_sockets_posix.h +2 -3
  566. data/src/core/lib/iomgr/wakeup_fd_nospecial.cc +1 -0
  567. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -3
  568. data/src/core/lib/iomgr/wakeup_fd_posix.cc +1 -0
  569. data/src/core/lib/iomgr/work_serializer.cc +4 -4
  570. data/src/core/lib/iomgr/work_serializer.h +1 -1
  571. data/src/core/lib/json/json_reader.cc +9 -17
  572. data/src/core/lib/json/json_util.h +18 -26
  573. data/src/core/lib/matchers/matchers.h +0 -1
  574. data/src/core/lib/profiling/basic_timers.cc +8 -6
  575. data/src/core/lib/profiling/stap_timers.cc +2 -2
  576. data/src/core/lib/security/authorization/authorization_policy_provider.h +5 -4
  577. data/src/core/lib/security/authorization/evaluate_args.cc +2 -0
  578. data/src/core/lib/security/authorization/sdk_server_authz_filter.cc +159 -0
  579. data/src/core/lib/security/authorization/sdk_server_authz_filter.h +67 -0
  580. data/src/core/lib/security/context/security_context.cc +7 -6
  581. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +2 -2
  582. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +2 -2
  583. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +2 -2
  584. data/src/core/lib/security/credentials/composite/composite_credentials.cc +4 -3
  585. data/src/core/lib/security/credentials/credentials.cc +6 -6
  586. data/src/core/lib/security/credentials/credentials.h +1 -1
  587. data/src/core/lib/security/credentials/credentials_metadata.cc +2 -3
  588. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +13 -26
  589. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -2
  590. data/src/core/lib/security/credentials/external/aws_request_signer.cc +3 -3
  591. data/src/core/lib/security/credentials/external/external_account_credentials.cc +13 -22
  592. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +2 -4
  593. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +1 -2
  594. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +55 -3
  595. data/src/core/lib/security/credentials/iam/iam_credentials.cc +2 -1
  596. data/src/core/lib/security/credentials/jwt/json_token.cc +1 -1
  597. data/src/core/lib/security/credentials/jwt/json_token.h +2 -1
  598. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +31 -14
  599. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +11 -3
  600. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +0 -2
  601. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +3 -3
  602. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +3 -7
  603. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -0
  604. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +2 -4
  605. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +4 -4
  606. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +0 -1
  607. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +3 -2
  608. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +10 -6
  609. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +2 -1
  610. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +7 -5
  611. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +2 -2
  612. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +4 -6
  613. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +1 -0
  614. data/src/core/lib/security/security_connector/load_system_roots_linux.cc +3 -3
  615. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +4 -7
  616. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +1 -2
  617. data/src/core/lib/security/security_connector/ssl_utils.cc +2 -3
  618. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +9 -14
  619. data/src/core/lib/security/transport/auth_filters.h +1 -0
  620. data/src/core/lib/security/transport/client_auth_filter.cc +4 -6
  621. data/src/core/lib/security/transport/secure_endpoint.cc +4 -14
  622. data/src/core/lib/security/transport/secure_endpoint.h +1 -0
  623. data/src/core/lib/security/transport/security_handshaker.cc +5 -4
  624. data/src/core/lib/security/transport/security_handshaker.h +2 -1
  625. data/src/core/lib/security/util/json_util.cc +6 -8
  626. data/src/core/lib/slice/percent_encoding.cc +73 -30
  627. data/src/core/lib/slice/percent_encoding.h +29 -28
  628. data/src/core/lib/slice/slice.cc +14 -5
  629. data/src/core/lib/slice/slice_buffer.cc +1 -2
  630. data/src/core/lib/slice/slice_intern.cc +2 -3
  631. data/src/core/lib/slice/slice_internal.h +2 -2
  632. data/src/core/lib/surface/api_trace.cc +2 -1
  633. data/src/core/lib/surface/api_trace.h +1 -0
  634. data/src/core/lib/surface/byte_buffer_reader.cc +1 -1
  635. data/src/core/lib/surface/call.cc +9 -8
  636. data/src/core/lib/surface/call.h +3 -3
  637. data/src/core/lib/surface/call_details.cc +2 -2
  638. data/src/core/lib/surface/call_log_batch.cc +2 -2
  639. data/src/core/lib/surface/channel.cc +22 -9
  640. data/src/core/lib/surface/channel.h +14 -2
  641. data/src/core/lib/surface/channel_ping.cc +1 -2
  642. data/src/core/lib/surface/channel_stack_type.cc +2 -1
  643. data/src/core/lib/surface/completion_queue.cc +54 -64
  644. data/src/core/lib/surface/completion_queue_factory.cc +2 -1
  645. data/src/core/lib/surface/completion_queue_factory.h +1 -0
  646. data/src/core/lib/surface/event_string.cc +1 -0
  647. data/src/core/lib/surface/init.cc +4 -9
  648. data/src/core/lib/surface/init.h +0 -1
  649. data/src/core/lib/surface/init_secure.cc +23 -4
  650. data/src/core/lib/surface/lame_client.cc +6 -5
  651. data/src/core/lib/surface/metadata_array.cc +2 -2
  652. data/src/core/lib/surface/server.cc +17 -33
  653. data/src/core/lib/surface/server.h +11 -13
  654. data/src/core/lib/surface/validate_metadata.cc +44 -16
  655. data/src/core/lib/surface/version.cc +2 -2
  656. data/src/core/lib/transport/byte_stream.h +1 -0
  657. data/src/core/lib/transport/connectivity_state.cc +8 -5
  658. data/src/core/lib/transport/connectivity_state.h +2 -2
  659. data/src/core/lib/transport/error_utils.cc +1 -0
  660. data/src/core/lib/transport/metadata.cc +10 -10
  661. data/src/core/lib/transport/metadata.h +13 -11
  662. data/src/core/lib/transport/metadata_batch.cc +13 -2
  663. data/src/core/lib/transport/metadata_batch.h +15 -0
  664. data/src/core/lib/transport/transport_op_string.cc +2 -2
  665. data/src/core/plugin_registry/grpc_plugin_registry.cc +14 -0
  666. data/src/core/tsi/alts/crypt/aes_gcm.cc +3 -2
  667. data/src/core/tsi/alts/crypt/gsec.h +2 -3
  668. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +2 -2
  669. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +2 -3
  670. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +2 -2
  671. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +4 -3
  672. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -2
  673. data/src/core/tsi/ssl_transport_security.cc +11 -9
  674. data/src/core/tsi/ssl_transport_security.h +3 -1
  675. data/src/core/tsi/transport_security.cc +3 -3
  676. data/src/core/tsi/transport_security_grpc.h +1 -0
  677. data/src/ruby/ext/grpc/extconf.rb +1 -1
  678. data/src/ruby/ext/grpc/rb_byte_buffer.c +2 -1
  679. data/src/ruby/ext/grpc/rb_call.c +5 -5
  680. data/src/ruby/ext/grpc/rb_call_credentials.c +5 -5
  681. data/src/ruby/ext/grpc/rb_channel.c +10 -8
  682. data/src/ruby/ext/grpc/rb_channel_args.c +2 -2
  683. data/src/ruby/ext/grpc/rb_channel_credentials.c +4 -4
  684. data/src/ruby/ext/grpc/rb_channel_credentials.h +1 -0
  685. data/src/ruby/ext/grpc/rb_completion_queue.c +3 -2
  686. data/src/ruby/ext/grpc/rb_compression_options.c +5 -4
  687. data/src/ruby/ext/grpc/rb_event_thread.c +4 -4
  688. data/src/ruby/ext/grpc/rb_grpc.c +5 -4
  689. data/src/ruby/ext/grpc/rb_grpc.h +1 -0
  690. data/src/ruby/ext/grpc/rb_server.c +6 -5
  691. data/src/ruby/ext/grpc/rb_server_credentials.c +3 -3
  692. data/src/ruby/ext/grpc/rb_server_credentials.h +1 -0
  693. data/src/ruby/ext/grpc/rb_xds_channel_credentials.c +8 -5
  694. data/src/ruby/ext/grpc/rb_xds_channel_credentials.h +3 -1
  695. data/src/ruby/ext/grpc/rb_xds_server_credentials.c +6 -5
  696. data/src/ruby/ext/grpc/rb_xds_server_credentials.h +3 -1
  697. data/src/ruby/lib/grpc/version.rb +1 -1
  698. data/third_party/boringssl-with-bazel/err_data.c +300 -292
  699. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +52 -47
  700. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +1 -1
  701. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +0 -2
  702. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +6 -1
  703. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +16 -23
  704. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +14 -7
  705. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_print.c +19 -29
  706. data/third_party/boringssl-with-bazel/src/crypto/{x509 → asn1}/a_strex.c +269 -272
  707. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +6 -43
  708. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +3 -3
  709. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +1 -1
  710. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +1 -40
  711. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utf8.c +1 -1
  712. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +1 -1
  713. data/third_party/boringssl-with-bazel/src/crypto/{x509 → asn1}/charmap.h +0 -0
  714. data/third_party/boringssl-with-bazel/src/crypto/asn1/{asn1_locl.h → internal.h} +45 -1
  715. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +9 -9
  716. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +290 -199
  717. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +9 -9
  718. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +10 -14
  719. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +2 -1
  720. data/third_party/boringssl-with-bazel/src/crypto/asn1/time_support.c +1 -1
  721. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +11 -8
  722. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +1 -7
  723. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +1 -5
  724. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +0 -4
  725. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +1 -7
  726. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +1 -6
  727. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +3 -17
  728. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +9 -0
  729. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +8 -0
  730. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/cipher_extra.c +45 -65
  731. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +14 -3
  732. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +6 -3
  733. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +26 -9
  734. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +3 -2
  735. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +5 -2
  736. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +10 -0
  737. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +2 -0
  738. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c +1 -1
  739. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +1 -1
  740. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +5 -9
  741. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +2 -2
  742. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +4 -6
  743. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +24 -9
  744. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +4 -2
  745. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +34 -0
  746. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +219 -121
  747. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +9 -2
  748. data/third_party/boringssl-with-bazel/src/crypto/internal.h +23 -2
  749. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +253 -0
  750. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +28 -23
  751. data/third_party/boringssl-with-bazel/src/crypto/mem.c +14 -9
  752. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +7 -3
  753. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +0 -9
  754. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +0 -2
  755. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +0 -8
  756. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +0 -2
  757. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +0 -4
  758. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +16 -7
  759. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +9 -4
  760. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +151 -12
  761. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +1 -1
  762. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +1 -1
  763. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +1 -0
  764. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +4 -0
  765. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/fuchsia.c +4 -0
  766. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +4 -0
  767. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +15 -11
  768. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +1 -1
  769. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +1 -0
  770. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +2 -0
  771. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +225 -2
  772. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +246 -0
  773. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +15 -4
  774. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +10 -5
  775. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +0 -179
  776. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +4 -2
  777. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +6 -23
  778. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +2 -2
  779. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +1 -5
  780. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +1 -0
  781. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +25 -22
  782. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +11 -54
  783. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +1 -1
  784. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +1 -0
  785. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +2 -4
  786. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +1 -3
  787. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +0 -16
  788. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +9 -11
  789. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +2 -0
  790. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +23 -21
  791. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +12 -11
  792. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +16 -0
  793. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_cache.c +1 -0
  794. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +1 -1
  795. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_int.h +1 -1
  796. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_map.c +1 -0
  797. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_tree.c +4 -3
  798. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +24 -5
  799. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +17 -8
  800. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +3 -0
  801. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +1 -0
  802. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +6 -6
  803. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_crld.c +4 -2
  804. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +5 -0
  805. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +2 -0
  806. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ncons.c +112 -55
  807. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pci.c +2 -1
  808. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +14 -13
  809. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +1 -0
  810. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +76 -31
  811. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +458 -260
  812. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +2 -9
  813. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +5 -4
  814. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +3 -1
  815. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +3 -3
  816. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +9 -0
  817. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +8 -2
  818. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +8 -5
  819. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +3 -0
  820. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +6 -0
  821. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +4 -0
  822. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +25 -0
  823. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +14 -12
  824. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +4 -205
  825. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +12 -3
  826. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +5 -4
  827. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +0 -20
  828. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +12 -5
  829. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +5 -0
  830. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +37 -15
  831. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +79 -13
  832. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +31 -32
  833. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +234 -131
  834. data/third_party/boringssl-with-bazel/src/include/openssl/x509_vfy.h +0 -131
  835. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +48 -13
  836. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +9 -16
  837. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +310 -359
  838. data/third_party/boringssl-with-bazel/src/ssl/{t1_lib.cc → extensions.cc} +110 -159
  839. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +24 -13
  840. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +145 -142
  841. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +106 -99
  842. data/third_party/boringssl-with-bazel/src/ssl/internal.h +87 -48
  843. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +1 -2
  844. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +2 -2
  845. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +11 -5
  846. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +2 -51
  847. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +121 -65
  848. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +6 -12
  849. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +28 -22
  850. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +14 -27
  851. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +210 -212
  852. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +30 -41
  853. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +48 -34
  854. data/third_party/upb/upb/decode.c +129 -60
  855. data/third_party/upb/upb/decode.h +32 -4
  856. data/third_party/upb/upb/decode_fast.c +513 -500
  857. data/third_party/upb/upb/decode_fast.h +27 -0
  858. data/third_party/upb/upb/{decode.int.h → decode_internal.h} +38 -8
  859. data/third_party/upb/upb/def.c +171 -181
  860. data/third_party/upb/upb/def.h +41 -19
  861. data/third_party/upb/upb/def.hpp +29 -0
  862. data/third_party/upb/upb/encode.c +49 -16
  863. data/third_party/upb/upb/encode.h +29 -2
  864. data/third_party/upb/upb/msg.c +169 -28
  865. data/third_party/upb/upb/msg.h +75 -580
  866. data/third_party/upb/upb/msg_internal.h +687 -0
  867. data/third_party/upb/upb/port_def.inc +85 -24
  868. data/third_party/upb/upb/port_undef.inc +38 -1
  869. data/third_party/upb/upb/reflection.c +29 -37
  870. data/third_party/upb/upb/reflection.h +36 -8
  871. data/third_party/upb/upb/reflection.hpp +37 -0
  872. data/third_party/upb/upb/table.c +211 -86
  873. data/third_party/upb/upb/{table.int.h → table_internal.h} +56 -180
  874. data/third_party/upb/upb/text_encode.c +32 -4
  875. data/third_party/upb/upb/text_encode.h +26 -0
  876. data/third_party/upb/upb/upb.c +59 -8
  877. data/third_party/upb/upb/upb.h +36 -6
  878. data/third_party/upb/upb/upb.hpp +24 -0
  879. data/third_party/upb/upb/upb_internal.h +58 -0
  880. metadata +70 -67
  881. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_libuv.cc +0 -179
  882. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +0 -38
  883. data/src/core/ext/transport/chttp2/transport/hpack_table.cc +0 -243
  884. data/src/core/ext/transport/chttp2/transport/hpack_table.h +0 -148
  885. data/src/core/lib/gpr/tls_gcc.h +0 -52
  886. data/src/core/lib/gpr/tls_msvc.h +0 -54
  887. data/src/core/lib/gpr/tls_pthread.cc +0 -30
  888. data/src/core/lib/gpr/tls_pthread.h +0 -56
  889. data/src/core/lib/gpr/tls_stdcpp.h +0 -48
  890. data/src/core/lib/gprpp/atomic.h +0 -104
  891. data/src/core/lib/iomgr/endpoint_pair_uv.cc +0 -40
  892. data/src/core/lib/iomgr/iomgr_uv.cc +0 -43
  893. data/src/core/lib/iomgr/pollset_uv.cc +0 -95
  894. data/src/core/lib/iomgr/pollset_uv.h +0 -36
  895. data/src/core/lib/iomgr/sockaddr_custom.h +0 -54
  896. data/src/core/lib/iomgr/socket_utils_uv.cc +0 -49
  897. data/src/core/lib/iomgr/tcp_uv.cc +0 -421
  898. data/src/core/lib/iomgr/timer_uv.cc +0 -66
  899. data/third_party/upb/third_party/wyhash/wyhash.h +0 -145
  900. data/third_party/upb/upb/upb.int.h +0 -29
@@ -27,13 +27,12 @@
27
27
 
28
28
  #include "absl/container/inlined_vector.h"
29
29
  #include "absl/types/optional.h"
30
+ #include "envoy/admin/v3/config_dump.upb.h"
30
31
  #include "re2/re2.h"
31
-
32
32
  #include "upb/def.hpp"
33
33
 
34
34
  #include <grpc/slice_buffer.h>
35
35
 
36
- #include "envoy/admin/v3/config_dump.upb.h"
37
36
  #include "src/core/ext/filters/client_channel/server_address.h"
38
37
  #include "src/core/ext/xds/xds_bootstrap.h"
39
38
  #include "src/core/ext/xds/xds_client_stats.h"
@@ -43,11 +42,6 @@
43
42
 
44
43
  namespace grpc_core {
45
44
 
46
- // TODO(yashykt): Check to see if xDS security is enabled. This will be
47
- // removed once this feature is fully integration-tested and enabled by
48
- // default.
49
- bool XdsSecurityEnabled();
50
-
51
45
  class XdsClient;
52
46
 
53
47
  class XdsApi {
@@ -194,22 +188,11 @@ class XdsApi {
194
188
  };
195
189
 
196
190
  struct CommonTlsContext {
197
- struct CertificateValidationContext {
198
- std::vector<StringMatcher> match_subject_alt_names;
199
-
200
- bool operator==(const CertificateValidationContext& other) const {
201
- return match_subject_alt_names == other.match_subject_alt_names;
202
- }
203
-
204
- std::string ToString() const;
205
- bool Empty() const;
206
- };
207
-
208
- struct CertificateProviderInstance {
191
+ struct CertificateProviderPluginInstance {
209
192
  std::string instance_name;
210
193
  std::string certificate_name;
211
194
 
212
- bool operator==(const CertificateProviderInstance& other) const {
195
+ bool operator==(const CertificateProviderPluginInstance& other) const {
213
196
  return instance_name == other.instance_name &&
214
197
  certificate_name == other.certificate_name;
215
198
  }
@@ -218,28 +201,28 @@ class XdsApi {
218
201
  bool Empty() const;
219
202
  };
220
203
 
221
- struct CombinedCertificateValidationContext {
222
- CertificateValidationContext default_validation_context;
223
- CertificateProviderInstance
224
- validation_context_certificate_provider_instance;
204
+ struct CertificateValidationContext {
205
+ CertificateProviderPluginInstance ca_certificate_provider_instance;
206
+ std::vector<StringMatcher> match_subject_alt_names;
225
207
 
226
- bool operator==(const CombinedCertificateValidationContext& other) const {
227
- return default_validation_context == other.default_validation_context &&
228
- validation_context_certificate_provider_instance ==
229
- other.validation_context_certificate_provider_instance;
208
+ bool operator==(const CertificateValidationContext& other) const {
209
+ return ca_certificate_provider_instance ==
210
+ other.ca_certificate_provider_instance &&
211
+ match_subject_alt_names == other.match_subject_alt_names;
230
212
  }
231
213
 
232
214
  std::string ToString() const;
233
215
  bool Empty() const;
234
216
  };
235
217
 
236
- CertificateProviderInstance tls_certificate_certificate_provider_instance;
237
- CombinedCertificateValidationContext combined_validation_context;
218
+ CertificateValidationContext certificate_validation_context;
219
+ CertificateProviderPluginInstance tls_certificate_provider_instance;
238
220
 
239
221
  bool operator==(const CommonTlsContext& other) const {
240
- return tls_certificate_certificate_provider_instance ==
241
- other.tls_certificate_certificate_provider_instance &&
242
- combined_validation_context == other.combined_validation_context;
222
+ return certificate_validation_context ==
223
+ other.certificate_validation_context &&
224
+ tls_certificate_provider_instance ==
225
+ other.tls_certificate_provider_instance;
243
226
  }
244
227
 
245
228
  std::string ToString() const;
@@ -18,11 +18,11 @@
18
18
 
19
19
  #include "src/core/ext/xds/xds_bootstrap.h"
20
20
 
21
- #include <vector>
22
-
23
21
  #include <errno.h>
24
22
  #include <stdlib.h>
25
23
 
24
+ #include <vector>
25
+
26
26
  #include "absl/strings/str_cat.h"
27
27
  #include "absl/strings/str_format.h"
28
28
  #include "absl/strings/str_join.h"
@@ -132,16 +132,14 @@ XdsBootstrap::XdsBootstrap(Json json, grpc_error_handle* error) {
132
132
  std::move(*it->second.mutable_string_value());
133
133
  }
134
134
  }
135
- if (XdsSecurityEnabled()) {
136
- it = json.mutable_object()->find("certificate_providers");
137
- if (it != json.mutable_object()->end()) {
138
- if (it->second.type() != Json::Type::OBJECT) {
139
- error_list.push_back(GRPC_ERROR_CREATE_FROM_STATIC_STRING(
140
- "\"certificate_providers\" field is not an object"));
141
- } else {
142
- grpc_error_handle parse_error = ParseCertificateProviders(&it->second);
143
- if (parse_error != GRPC_ERROR_NONE) error_list.push_back(parse_error);
144
- }
135
+ it = json.mutable_object()->find("certificate_providers");
136
+ if (it != json.mutable_object()->end()) {
137
+ if (it->second.type() != Json::Type::OBJECT) {
138
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_STATIC_STRING(
139
+ "\"certificate_providers\" field is not an object"));
140
+ } else {
141
+ grpc_error_handle parse_error = ParseCertificateProviders(&it->second);
142
+ if (parse_error != GRPC_ERROR_NONE) error_list.push_back(parse_error);
145
143
  }
146
144
  }
147
145
  *error = GRPC_ERROR_CREATE_FROM_VECTOR("errors parsing xds bootstrap file",
@@ -153,8 +151,8 @@ grpc_error_handle XdsBootstrap::ParseXdsServerList(Json* json) {
153
151
  for (size_t i = 0; i < json->mutable_array()->size(); ++i) {
154
152
  Json& child = json->mutable_array()->at(i);
155
153
  if (child.type() != Json::Type::OBJECT) {
156
- error_list.push_back(GRPC_ERROR_CREATE_FROM_COPIED_STRING(
157
- absl::StrCat("array element ", i, " is not an object").c_str()));
154
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_CPP_STRING(
155
+ absl::StrCat("array element ", i, " is not an object")));
158
156
  } else {
159
157
  grpc_error_handle parse_error = ParseXdsServer(&child, i);
160
158
  if (parse_error != GRPC_ERROR_NONE) error_list.push_back(parse_error);
@@ -201,15 +199,8 @@ grpc_error_handle XdsBootstrap::ParseXdsServer(Json* json, size_t idx) {
201
199
  if (parse_error != GRPC_ERROR_NONE) error_list.push_back(parse_error);
202
200
  }
203
201
  }
204
- // Can't use GRPC_ERROR_CREATE_FROM_VECTOR() here, because the error
205
- // string is not static in this case.
206
- if (error_list.empty()) return GRPC_ERROR_NONE;
207
- grpc_error_handle error = GRPC_ERROR_CREATE_FROM_COPIED_STRING(
208
- absl::StrCat("errors parsing index ", idx).c_str());
209
- for (size_t i = 0; i < error_list.size(); ++i) {
210
- error = grpc_error_add_child(error, error_list[i]);
211
- }
212
- return error;
202
+ return GRPC_ERROR_CREATE_FROM_VECTOR_AND_CPP_STRING(
203
+ absl::StrCat("errors parsing index ", idx), &error_list);
213
204
  }
214
205
 
215
206
  grpc_error_handle XdsBootstrap::ParseChannelCredsArray(Json* json,
@@ -218,8 +209,8 @@ grpc_error_handle XdsBootstrap::ParseChannelCredsArray(Json* json,
218
209
  for (size_t i = 0; i < json->mutable_array()->size(); ++i) {
219
210
  Json& child = json->mutable_array()->at(i);
220
211
  if (child.type() != Json::Type::OBJECT) {
221
- error_list.push_back(GRPC_ERROR_CREATE_FROM_COPIED_STRING(
222
- absl::StrCat("array element ", i, " is not an object").c_str()));
212
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_CPP_STRING(
213
+ absl::StrCat("array element ", i, " is not an object")));
223
214
  } else {
224
215
  grpc_error_handle parse_error = ParseChannelCreds(&child, i, server);
225
216
  if (parse_error != GRPC_ERROR_NONE) error_list.push_back(parse_error);
@@ -261,22 +252,14 @@ grpc_error_handle XdsBootstrap::ParseChannelCreds(Json* json, size_t idx,
261
252
  if (server->channel_creds_type.empty() &&
262
253
  XdsChannelCredsRegistry::IsSupported(type)) {
263
254
  if (!XdsChannelCredsRegistry::IsValidConfig(type, config)) {
264
- error_list.push_back(GRPC_ERROR_CREATE_FROM_COPIED_STRING(
265
- absl::StrCat("invalid config for channel creds type \"", type, "\"")
266
- .c_str()));
255
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrCat(
256
+ "invalid config for channel creds type \"", type, "\"")));
267
257
  }
268
258
  server->channel_creds_type = std::move(type);
269
259
  server->channel_creds_config = std::move(config);
270
260
  }
271
- // Can't use GRPC_ERROR_CREATE_FROM_VECTOR() here, because the error
272
- // string is not static in this case.
273
- if (error_list.empty()) return GRPC_ERROR_NONE;
274
- grpc_error_handle error = GRPC_ERROR_CREATE_FROM_COPIED_STRING(
275
- absl::StrCat("errors parsing index ", idx).c_str());
276
- for (size_t i = 0; i < error_list.size(); ++i) {
277
- error = grpc_error_add_child(error, error_list[i]);
278
- }
279
- return error;
261
+ return GRPC_ERROR_CREATE_FROM_VECTOR_AND_CPP_STRING(
262
+ absl::StrCat("errors parsing index ", idx), &error_list);
280
263
  }
281
264
 
282
265
  grpc_error_handle XdsBootstrap::ParseServerFeaturesArray(Json* json,
@@ -374,10 +357,8 @@ grpc_error_handle XdsBootstrap::ParseCertificateProviders(Json* json) {
374
357
  std::vector<grpc_error_handle> error_list;
375
358
  for (auto& certificate_provider : *(json->mutable_object())) {
376
359
  if (certificate_provider.second.type() != Json::Type::OBJECT) {
377
- error_list.push_back(GRPC_ERROR_CREATE_FROM_COPIED_STRING(
378
- absl::StrCat("element \"", certificate_provider.first,
379
- "\" is not an object")
380
- .c_str()));
360
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrCat(
361
+ "element \"", certificate_provider.first, "\" is not an object")));
381
362
  } else {
382
363
  grpc_error_handle parse_error = ParseCertificateProvider(
383
364
  certificate_provider.first, &certificate_provider.second);
@@ -404,8 +385,8 @@ grpc_error_handle XdsBootstrap::ParseCertificateProvider(
404
385
  CertificateProviderRegistry::LookupCertificateProviderFactory(
405
386
  plugin_name);
406
387
  if (factory == nullptr) {
407
- error_list.push_back(GRPC_ERROR_CREATE_FROM_COPIED_STRING(
408
- absl::StrCat("Unrecognized plugin name: ", plugin_name).c_str()));
388
+ error_list.push_back(GRPC_ERROR_CREATE_FROM_CPP_STRING(
389
+ absl::StrCat("Unrecognized plugin name: ", plugin_name)));
409
390
  } else {
410
391
  RefCountedPtr<CertificateProviderFactory::Config> config;
411
392
  it = certificate_provider_json->mutable_object()->find("config");
@@ -430,15 +411,9 @@ grpc_error_handle XdsBootstrap::ParseCertificateProvider(
430
411
  {instance_name, {std::move(plugin_name), std::move(config)}});
431
412
  }
432
413
  }
433
- // Can't use GRPC_ERROR_CREATE_FROM_VECTOR() here, because the error
434
- // string is not static in this case.
435
- if (error_list.empty()) return GRPC_ERROR_NONE;
436
- grpc_error_handle error = GRPC_ERROR_CREATE_FROM_COPIED_STRING(
437
- absl::StrCat("errors parsing element \"", instance_name, "\"").c_str());
438
- for (size_t i = 0; i < error_list.size(); ++i) {
439
- error = grpc_error_add_child(error, error_list[i]);
440
- }
441
- return error;
414
+ return GRPC_ERROR_CREATE_FROM_VECTOR_AND_CPP_STRING(
415
+ absl::StrCat("errors parsing element \"", instance_name, "\""),
416
+ &error_list);
442
417
  }
443
418
 
444
419
  std::string XdsBootstrap::ToString() const {
@@ -16,6 +16,8 @@
16
16
 
17
17
  #include <grpc/support/port_platform.h>
18
18
 
19
+ #include "src/core/ext/xds/xds_client.h"
20
+
19
21
  #include <inttypes.h>
20
22
  #include <limits.h>
21
23
  #include <string.h>
@@ -35,7 +37,6 @@
35
37
  #include "src/core/ext/xds/xds_api.h"
36
38
  #include "src/core/ext/xds/xds_bootstrap.h"
37
39
  #include "src/core/ext/xds/xds_channel_args.h"
38
- #include "src/core/ext/xds/xds_client.h"
39
40
  #include "src/core/ext/xds/xds_client_stats.h"
40
41
  #include "src/core/ext/xds/xds_http_filters.h"
41
42
  #include "src/core/lib/address_utils/sockaddr_utils.h"
@@ -193,11 +194,10 @@ class XdsClient::ChannelState::AdsCallState
193
194
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_) {
194
195
  if (error == GRPC_ERROR_NONE && timer_pending_) {
195
196
  timer_pending_ = false;
196
- grpc_error_handle watcher_error = GRPC_ERROR_CREATE_FROM_COPIED_STRING(
197
- absl::StrFormat(
197
+ grpc_error_handle watcher_error =
198
+ GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrFormat(
198
199
  "timeout obtaining resource {type=%s name=%s} from xds server",
199
- type_url_, name_)
200
- .c_str());
200
+ type_url_, name_));
201
201
  watcher_error = grpc_error_set_int(
202
202
  watcher_error, GRPC_ERROR_INT_GRPC_STATUS, GRPC_STATUS_UNAVAILABLE);
203
203
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_client_trace)) {
@@ -263,13 +263,15 @@ class XdsClient::ChannelState::AdsCallState
263
263
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
264
264
 
265
265
  void AcceptLdsUpdateLocked(std::string version, grpc_millis update_time,
266
- XdsApi::LdsUpdateMap lds_update_map)
266
+ XdsApi::LdsUpdateMap lds_update_map,
267
+ const std::set<std::string>& resource_names_failed)
267
268
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
268
269
  void AcceptRdsUpdateLocked(std::string version, grpc_millis update_time,
269
270
  XdsApi::RdsUpdateMap rds_update_map)
270
271
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
271
272
  void AcceptCdsUpdateLocked(std::string version, grpc_millis update_time,
272
- XdsApi::CdsUpdateMap cds_update_map)
273
+ XdsApi::CdsUpdateMap cds_update_map,
274
+ const std::set<std::string>& resource_names_failed)
273
275
  ABSL_EXCLUSIVE_LOCKS_REQUIRED(&XdsClient::mu_);
274
276
  void AcceptEdsUpdateLocked(std::string version, grpc_millis update_time,
275
277
  XdsApi::EdsUpdateMap eds_update_map)
@@ -904,7 +906,8 @@ XdsApi::ResourceMetadata CreateResourceMetadataAcked(
904
906
 
905
907
  void XdsClient::ChannelState::AdsCallState::AcceptLdsUpdateLocked(
906
908
  std::string version, grpc_millis update_time,
907
- XdsApi::LdsUpdateMap lds_update_map) {
909
+ XdsApi::LdsUpdateMap lds_update_map,
910
+ const std::set<std::string>& resource_names_failed) {
908
911
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_client_trace)) {
909
912
  gpr_log(GPR_INFO,
910
913
  "[xds_client %p] LDS update received containing %" PRIuPTR
@@ -948,6 +951,21 @@ void XdsClient::ChannelState::AdsCallState::AcceptLdsUpdateLocked(
948
951
  p.first->OnListenerChanged(*listener_state.update);
949
952
  }
950
953
  }
954
+ // For invalid resources in the update, if they are already in the
955
+ // cache, pretend that they are present in the update, so that we
956
+ // don't incorrectly consider them deleted below.
957
+ for (const std::string& listener_name : resource_names_failed) {
958
+ auto it = xds_client()->listener_map_.find(listener_name);
959
+ if (it != xds_client()->listener_map_.end()) {
960
+ auto& resource = it->second.update;
961
+ if (!resource.has_value()) continue;
962
+ lds_update_map[listener_name];
963
+ if (!resource->http_connection_manager.route_config_name.empty()) {
964
+ rds_resource_names_seen.insert(
965
+ resource->http_connection_manager.route_config_name);
966
+ }
967
+ }
968
+ }
951
969
  // For any subscribed resource that is not present in the update,
952
970
  // remove it from the cache and notify watchers that it does not exist.
953
971
  for (const auto& p : lds_state.subscribed_resources) {
@@ -1030,7 +1048,8 @@ void XdsClient::ChannelState::AdsCallState::AcceptRdsUpdateLocked(
1030
1048
 
1031
1049
  void XdsClient::ChannelState::AdsCallState::AcceptCdsUpdateLocked(
1032
1050
  std::string version, grpc_millis update_time,
1033
- XdsApi::CdsUpdateMap cds_update_map) {
1051
+ XdsApi::CdsUpdateMap cds_update_map,
1052
+ const std::set<std::string>& resource_names_failed) {
1034
1053
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_client_trace)) {
1035
1054
  gpr_log(GPR_INFO,
1036
1055
  "[xds_client %p] CDS update received containing %" PRIuPTR
@@ -1072,6 +1091,20 @@ void XdsClient::ChannelState::AdsCallState::AcceptCdsUpdateLocked(
1072
1091
  p.first->OnClusterChanged(cluster_state.update.value());
1073
1092
  }
1074
1093
  }
1094
+ // For invalid resources in the update, if they are already in the
1095
+ // cache, pretend that they are present in the update, so that we
1096
+ // don't incorrectly consider them deleted below.
1097
+ for (const std::string& cluster_name : resource_names_failed) {
1098
+ auto it = xds_client()->cluster_map_.find(cluster_name);
1099
+ if (it != xds_client()->cluster_map_.end()) {
1100
+ auto& resource = it->second.update;
1101
+ if (!resource.has_value()) continue;
1102
+ cds_update_map[cluster_name];
1103
+ eds_resource_names_seen.insert(resource->eds_service_name.empty()
1104
+ ? cluster_name
1105
+ : resource->eds_service_name);
1106
+ }
1107
+ }
1075
1108
  // For any subscribed resource that is not present in the update,
1076
1109
  // remove it from the cache and notify watchers that it does not exist.
1077
1110
  for (const auto& p : cds_state.subscribed_resources) {
@@ -1173,7 +1206,7 @@ void XdsClient::ChannelState::AdsCallState::RejectAdsUpdateLocked(
1173
1206
  if (GRPC_TRACE_FLAG_ENABLED(grpc_xds_client_trace)) {
1174
1207
  gpr_log(GPR_INFO,
1175
1208
  "[xds_client %p] %s update NACKed containing %" PRIuPTR
1176
- " resources",
1209
+ " invalid resources",
1177
1210
  xds_client(), result.type_url.c_str(),
1178
1211
  result.resource_names_failed.size());
1179
1212
  }
@@ -1268,9 +1301,8 @@ bool XdsClient::ChannelState::AdsCallState::OnResponseReceivedLocked() {
1268
1301
  // Update nonce.
1269
1302
  auto& state = state_map_[result.type_url];
1270
1303
  state.nonce = std::move(result.nonce);
1271
- // NACK or ACK the response.
1304
+ // If we got an error, we'll NACK the update.
1272
1305
  if (result.parse_error != GRPC_ERROR_NONE) {
1273
- // NACK unacceptable update.
1274
1306
  gpr_log(GPR_ERROR,
1275
1307
  "[xds_client %p] ADS response invalid for resource type %s "
1276
1308
  "version %s, will NACK: nonce=%s error=%s",
@@ -1294,27 +1326,32 @@ bool XdsClient::ChannelState::AdsCallState::OnResponseReceivedLocked() {
1294
1326
  RejectAdsUpdateLocked(update_time, result,
1295
1327
  &xds_client()->endpoint_map_);
1296
1328
  }
1297
- SendMessageLocked(result.type_url);
1298
- } else {
1329
+ }
1330
+ // Process any valid resources.
1331
+ bool have_valid_resources = false;
1332
+ if (result.type_url == XdsApi::kLdsTypeUrl) {
1333
+ have_valid_resources = !result.lds_update_map.empty();
1334
+ AcceptLdsUpdateLocked(result.version, update_time,
1335
+ std::move(result.lds_update_map),
1336
+ result.resource_names_failed);
1337
+ } else if (result.type_url == XdsApi::kRdsTypeUrl) {
1338
+ have_valid_resources = !result.rds_update_map.empty();
1339
+ AcceptRdsUpdateLocked(result.version, update_time,
1340
+ std::move(result.rds_update_map));
1341
+ } else if (result.type_url == XdsApi::kCdsTypeUrl) {
1342
+ have_valid_resources = !result.cds_update_map.empty();
1343
+ AcceptCdsUpdateLocked(result.version, update_time,
1344
+ std::move(result.cds_update_map),
1345
+ result.resource_names_failed);
1346
+ } else if (result.type_url == XdsApi::kEdsTypeUrl) {
1347
+ have_valid_resources = !result.eds_update_map.empty();
1348
+ AcceptEdsUpdateLocked(result.version, update_time,
1349
+ std::move(result.eds_update_map));
1350
+ }
1351
+ if (have_valid_resources) {
1299
1352
  seen_response_ = true;
1300
- // Accept the ADS response according to the type_url.
1301
- if (result.type_url == XdsApi::kLdsTypeUrl) {
1302
- AcceptLdsUpdateLocked(result.version, update_time,
1303
- std::move(result.lds_update_map));
1304
- } else if (result.type_url == XdsApi::kRdsTypeUrl) {
1305
- AcceptRdsUpdateLocked(result.version, update_time,
1306
- std::move(result.rds_update_map));
1307
- } else if (result.type_url == XdsApi::kCdsTypeUrl) {
1308
- AcceptCdsUpdateLocked(result.version, update_time,
1309
- std::move(result.cds_update_map));
1310
- } else if (result.type_url == XdsApi::kEdsTypeUrl) {
1311
- AcceptEdsUpdateLocked(result.version, update_time,
1312
- std::move(result.eds_update_map));
1313
- }
1314
1353
  xds_client()->resource_version_map_[result.type_url] =
1315
1354
  std::move(result.version);
1316
- // ACK the update.
1317
- SendMessageLocked(result.type_url);
1318
1355
  // Start load reporting if needed.
1319
1356
  auto& lrs_call = chand()->lrs_calld_;
1320
1357
  if (lrs_call != nullptr) {
@@ -1322,6 +1359,8 @@ bool XdsClient::ChannelState::AdsCallState::OnResponseReceivedLocked() {
1322
1359
  if (lrs_calld != nullptr) lrs_calld->MaybeStartReportingLocked();
1323
1360
  }
1324
1361
  }
1362
+ // Send ACK or NACK.
1363
+ SendMessageLocked(result.type_url);
1325
1364
  }
1326
1365
  if (xds_client()->shutting_down_) return true;
1327
1366
  // Keep listening for updates.
@@ -31,8 +31,8 @@ namespace grpc_core {
31
31
 
32
32
  namespace {
33
33
 
34
- uint64_t GetAndResetCounter(Atomic<uint64_t>* from) {
35
- return from->Exchange(0, MemoryOrder::RELAXED);
34
+ uint64_t GetAndResetCounter(std::atomic<uint64_t>* from) {
35
+ return from->exchange(0, std::memory_order_relaxed);
36
36
  }
37
37
 
38
38
  } // namespace
@@ -82,7 +82,7 @@ XdsClusterDropStats::Snapshot XdsClusterDropStats::GetSnapshotAndReset() {
82
82
  }
83
83
 
84
84
  void XdsClusterDropStats::AddUncategorizedDrops() {
85
- uncategorized_drops_.FetchAdd(1);
85
+ uncategorized_drops_.fetch_add(1);
86
86
  }
87
87
 
88
88
  void XdsClusterDropStats::AddCallDropped(const std::string& category) {
@@ -132,28 +132,29 @@ XdsClusterLocalityStats::~XdsClusterLocalityStats() {
132
132
 
133
133
  XdsClusterLocalityStats::Snapshot
134
134
  XdsClusterLocalityStats::GetSnapshotAndReset() {
135
- Snapshot snapshot = {GetAndResetCounter(&total_successful_requests_),
136
- // Don't reset total_requests_in_progress because it's
137
- // not related to a single reporting interval.
138
- total_requests_in_progress_.Load(MemoryOrder::RELAXED),
139
- GetAndResetCounter(&total_error_requests_),
140
- GetAndResetCounter(&total_issued_requests_),
141
- {}};
135
+ Snapshot snapshot = {
136
+ GetAndResetCounter(&total_successful_requests_),
137
+ // Don't reset total_requests_in_progress because it's
138
+ // not related to a single reporting interval.
139
+ total_requests_in_progress_.load(std::memory_order_relaxed),
140
+ GetAndResetCounter(&total_error_requests_),
141
+ GetAndResetCounter(&total_issued_requests_),
142
+ {}};
142
143
  MutexLock lock(&backend_metrics_mu_);
143
144
  snapshot.backend_metrics = std::move(backend_metrics_);
144
145
  return snapshot;
145
146
  }
146
147
 
147
148
  void XdsClusterLocalityStats::AddCallStarted() {
148
- total_issued_requests_.FetchAdd(1, MemoryOrder::RELAXED);
149
- total_requests_in_progress_.FetchAdd(1, MemoryOrder::RELAXED);
149
+ total_issued_requests_.fetch_add(1, std::memory_order_relaxed);
150
+ total_requests_in_progress_.fetch_add(1, std::memory_order_relaxed);
150
151
  }
151
152
 
152
153
  void XdsClusterLocalityStats::AddCallFinished(bool fail) {
153
- Atomic<uint64_t>& to_increment =
154
+ std::atomic<uint64_t>& to_increment =
154
155
  fail ? total_error_requests_ : total_successful_requests_;
155
- to_increment.FetchAdd(1, MemoryOrder::RELAXED);
156
- total_requests_in_progress_.FetchAdd(-1, MemoryOrder::ACQ_REL);
156
+ to_increment.fetch_add(1, std::memory_order_relaxed);
157
+ total_requests_in_progress_.fetch_add(-1, std::memory_order_acq_rel);
157
158
  }
158
159
 
159
160
  } // namespace grpc_core
@@ -21,6 +21,7 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
+ #include <atomic>
24
25
  #include <map>
25
26
  #include <string>
26
27
 
@@ -29,7 +30,6 @@
29
30
  #include "absl/strings/string_view.h"
30
31
 
31
32
  #include "src/core/lib/gpr/useful.h"
32
- #include "src/core/lib/gprpp/atomic.h"
33
33
  #include "src/core/lib/gprpp/memory.h"
34
34
  #include "src/core/lib/gprpp/ref_counted.h"
35
35
  #include "src/core/lib/gprpp/sync.h"
@@ -144,7 +144,7 @@ class XdsClusterDropStats : public RefCounted<XdsClusterDropStats> {
144
144
  absl::string_view lrs_server_name_;
145
145
  absl::string_view cluster_name_;
146
146
  absl::string_view eds_service_name_;
147
- Atomic<uint64_t> uncategorized_drops_{0};
147
+ std::atomic<uint64_t> uncategorized_drops_{0};
148
148
  // Protects categorized_drops_. A mutex is necessary because the length of
149
149
  // dropped_requests can be accessed by both the picker (from data plane
150
150
  // mutex) and the load reporting thread (from the control plane combiner).
@@ -221,10 +221,10 @@ class XdsClusterLocalityStats : public RefCounted<XdsClusterLocalityStats> {
221
221
  absl::string_view eds_service_name_;
222
222
  RefCountedPtr<XdsLocalityName> name_;
223
223
 
224
- Atomic<uint64_t> total_successful_requests_{0};
225
- Atomic<uint64_t> total_requests_in_progress_{0};
226
- Atomic<uint64_t> total_error_requests_{0};
227
- Atomic<uint64_t> total_issued_requests_{0};
224
+ std::atomic<uint64_t> total_successful_requests_{0};
225
+ std::atomic<uint64_t> total_requests_in_progress_{0};
226
+ std::atomic<uint64_t> total_error_requests_{0};
227
+ std::atomic<uint64_t> total_issued_requests_{0};
228
228
 
229
229
  // Protects backend_metrics_. A mutex is necessary because the length of
230
230
  // backend_metrics_ can be accessed by both the callback intercepting the
@@ -18,8 +18,6 @@
18
18
 
19
19
  #include "src/core/ext/xds/xds_http_fault_filter.h"
20
20
 
21
- #include <grpc/grpc.h>
22
-
23
21
  #include <string>
24
22
 
25
23
  #include "absl/status/statusor.h"
@@ -33,6 +31,10 @@
33
31
  #include "google/protobuf/any.upb.h"
34
32
  #include "google/protobuf/duration.upb.h"
35
33
  #include "google/protobuf/wrappers.upb.h"
34
+ #include "upb/def.h"
35
+
36
+ #include <grpc/grpc.h>
37
+
36
38
  #include "src/core/ext/filters/fault_injection/fault_injection_filter.h"
37
39
  #include "src/core/ext/xds/xds_http_filters.h"
38
40
  #include "src/core/lib/channel/channel_args.h"
@@ -40,7 +42,6 @@
40
42
  #include "src/core/lib/channel/status_util.h"
41
43
  #include "src/core/lib/json/json.h"
42
44
  #include "src/core/lib/transport/status_conversion.h"
43
- #include "upb/def.h"
44
45
 
45
46
  namespace grpc_core {
46
47
 
@@ -19,11 +19,12 @@
19
19
 
20
20
  #include <grpc/support/port_platform.h>
21
21
 
22
+ #include "absl/status/statusor.h"
23
+ #include "upb/def.h"
24
+
22
25
  #include <grpc/grpc.h>
23
26
 
24
- #include "absl/status/statusor.h"
25
27
  #include "src/core/ext/xds/xds_http_filters.h"
26
- #include "upb/def.h"
27
28
 
28
29
  namespace grpc_core {
29
30
 
@@ -20,6 +20,7 @@
20
20
 
21
21
  #include "envoy/extensions/filters/http/router/v3/router.upb.h"
22
22
  #include "envoy/extensions/filters/http/router/v3/router.upbdefs.h"
23
+
23
24
  #include "src/core/ext/xds/xds_http_fault_filter.h"
24
25
 
25
26
  namespace grpc_core {
@@ -259,12 +259,12 @@ FilterChainMatchManager::CreateOrGetXdsCertificateProviderFromFilterChainData(
259
259
  // Configure root cert.
260
260
  absl::string_view root_provider_instance_name =
261
261
  filter_chain->downstream_tls_context.common_tls_context
262
- .combined_validation_context
263
- .validation_context_certificate_provider_instance.instance_name;
262
+ .certificate_validation_context.ca_certificate_provider_instance
263
+ .instance_name;
264
264
  absl::string_view root_provider_cert_name =
265
265
  filter_chain->downstream_tls_context.common_tls_context
266
- .combined_validation_context
267
- .validation_context_certificate_provider_instance.certificate_name;
266
+ .certificate_validation_context.ca_certificate_provider_instance
267
+ .certificate_name;
268
268
  if (!root_provider_instance_name.empty()) {
269
269
  certificate_providers.root =
270
270
  xds_client_->certificate_provider_store()
@@ -278,10 +278,10 @@ FilterChainMatchManager::CreateOrGetXdsCertificateProviderFromFilterChainData(
278
278
  // Configure identity cert.
279
279
  absl::string_view identity_provider_instance_name =
280
280
  filter_chain->downstream_tls_context.common_tls_context
281
- .tls_certificate_certificate_provider_instance.instance_name;
281
+ .tls_certificate_provider_instance.instance_name;
282
282
  absl::string_view identity_provider_cert_name =
283
283
  filter_chain->downstream_tls_context.common_tls_context
284
- .tls_certificate_certificate_provider_instance.certificate_name;
284
+ .tls_certificate_provider_instance.certificate_name;
285
285
  if (!identity_provider_instance_name.empty()) {
286
286
  certificate_providers.instance =
287
287
  xds_client_->certificate_provider_store()
@@ -428,7 +428,7 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
428
428
  if (serving_status_notifier_.on_serving_status_update != nullptr) {
429
429
  serving_status_notifier_.on_serving_status_update(
430
430
  serving_status_notifier_.user_data, listening_address_.c_str(),
431
- GRPC_STATUS_OK, "");
431
+ {GRPC_STATUS_OK, ""});
432
432
  } else {
433
433
  gpr_log(GPR_INFO,
434
434
  "xDS Listener resource obtained; will start serving on %s",
@@ -459,7 +459,7 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
459
459
  if (serving_status_notifier_.on_serving_status_update != nullptr) {
460
460
  serving_status_notifier_.on_serving_status_update(
461
461
  serving_status_notifier_.user_data, listening_address_.c_str(),
462
- GRPC_STATUS_UNAVAILABLE, grpc_error_std_string(error).c_str());
462
+ {GRPC_STATUS_UNAVAILABLE, grpc_error_std_string(error).c_str()});
463
463
  } else {
464
464
  gpr_log(
465
465
  GPR_ERROR,
@@ -486,8 +486,8 @@ class XdsServerConfigFetcher : public grpc_server_config_fetcher {
486
486
  if (serving_status_notifier_.on_serving_status_update != nullptr) {
487
487
  serving_status_notifier_.on_serving_status_update(
488
488
  serving_status_notifier_.user_data, listening_address_.c_str(),
489
- static_cast<grpc_status_code>(status.raw_code()),
490
- std::string(status.message()).c_str());
489
+ {static_cast<grpc_status_code>(status.raw_code()),
490
+ std::string(status.message()).c_str()});
491
491
  }
492
492
  }
493
493