grpc 1.44.0.pre2 → 1.46.3

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 (1167) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +311 -191
  3. data/include/grpc/event_engine/event_engine.h +2 -2
  4. data/include/grpc/grpc.h +40 -14
  5. data/include/grpc/grpc_posix.h +20 -19
  6. data/include/grpc/grpc_security.h +26 -50
  7. data/include/grpc/impl/codegen/grpc_types.h +18 -21
  8. data/include/grpc/impl/codegen/port_platform.h +2 -2
  9. data/include/grpc/impl/codegen/slice.h +4 -1
  10. data/include/grpc/slice.h +0 -11
  11. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +309 -0
  12. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +122 -0
  13. data/src/core/ext/filters/{client_idle → channel_idle}/idle_filter_state.cc +1 -1
  14. data/src/core/ext/filters/{client_idle → channel_idle}/idle_filter_state.h +5 -5
  15. data/src/core/ext/filters/client_channel/backend_metric.cc +3 -3
  16. data/src/core/ext/filters/client_channel/backup_poller.cc +12 -8
  17. data/src/core/ext/filters/client_channel/channel_connectivity.cc +5 -5
  18. data/src/core/ext/filters/client_channel/client_channel.cc +242 -153
  19. data/src/core/ext/filters/client_channel/client_channel.h +32 -29
  20. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +5 -11
  21. data/src/core/ext/filters/client_channel/connector.h +1 -1
  22. data/src/core/ext/filters/client_channel/dynamic_filters.cc +1 -2
  23. data/src/core/ext/filters/client_channel/dynamic_filters.h +1 -1
  24. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +2 -22
  25. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +3 -15
  26. data/src/core/ext/filters/client_channel/health/health_check_client.cc +124 -582
  27. data/src/core/ext/filters/client_channel/health/health_check_client.h +24 -160
  28. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +9 -12
  29. data/src/core/ext/filters/client_channel/http_proxy.cc +88 -110
  30. data/src/core/ext/filters/client_channel/http_proxy.h +17 -0
  31. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +1 -0
  32. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +68 -47
  33. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +15 -15
  34. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +4 -4
  35. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +7 -3
  36. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +193 -148
  37. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +2 -6
  38. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +120 -92
  39. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +88 -59
  40. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +60 -52
  41. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +51 -24
  42. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +16 -8
  43. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +245 -293
  44. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +7 -13
  45. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +126 -278
  46. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +18 -19
  47. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +62 -234
  48. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +8 -7
  49. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +82 -57
  50. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +201 -0
  51. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +106 -0
  52. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +35 -34
  53. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +135 -89
  54. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +7 -10
  55. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +11 -5
  56. data/src/core/ext/filters/client_channel/retry_filter.cc +236 -127
  57. data/src/core/ext/filters/client_channel/retry_service_config.cc +15 -17
  58. data/src/core/ext/filters/client_channel/retry_service_config.h +17 -11
  59. data/src/core/ext/filters/client_channel/retry_throttle.cc +9 -23
  60. data/src/core/ext/filters/client_channel/retry_throttle.h +11 -5
  61. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +7 -6
  62. data/src/core/ext/filters/client_channel/subchannel.cc +38 -41
  63. data/src/core/ext/filters/client_channel/subchannel.h +5 -4
  64. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +544 -0
  65. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +214 -0
  66. data/src/core/ext/filters/deadline/deadline_filter.cc +15 -14
  67. data/src/core/ext/filters/deadline/deadline_filter.h +3 -2
  68. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +133 -367
  69. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +24 -1
  70. data/src/core/ext/filters/fault_injection/service_config_parser.cc +5 -5
  71. data/src/core/ext/filters/fault_injection/service_config_parser.h +9 -3
  72. data/src/core/ext/filters/http/client/http_client_filter.cc +79 -455
  73. data/src/core/ext/filters/http/client/http_client_filter.h +21 -4
  74. data/src/core/ext/filters/http/client_authority_filter.cc +31 -79
  75. data/src/core/ext/filters/http/client_authority_filter.h +24 -5
  76. data/src/core/ext/filters/http/http_filters_plugin.cc +20 -18
  77. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +1 -0
  78. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +10 -2
  79. data/src/core/ext/filters/http/server/http_server_filter.cc +3 -116
  80. data/src/core/ext/filters/message_size/message_size_filter.cc +26 -34
  81. data/src/core/ext/filters/message_size/message_size_filter.h +9 -2
  82. data/src/core/ext/filters/rbac/rbac_filter.cc +13 -8
  83. data/src/core/ext/filters/rbac/rbac_filter.h +2 -0
  84. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +6 -5
  85. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +6 -1
  86. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +2 -8
  87. data/src/core/ext/filters/server_config_selector/server_config_selector.h +2 -2
  88. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +73 -200
  89. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +235 -0
  90. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +153 -10
  91. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +233 -59
  92. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +8 -2
  93. data/src/core/ext/transport/chttp2/transport/flow_control.cc +2 -2
  94. data/src/core/ext/transport/chttp2/transport/flow_control.h +3 -3
  95. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -4
  96. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +5 -0
  97. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +2 -0
  98. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +3 -8
  99. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +1 -1
  100. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +15 -51
  101. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +2 -2
  102. data/src/core/ext/transport/chttp2/transport/internal.h +10 -8
  103. data/src/core/ext/transport/chttp2/transport/parsing.cc +11 -3
  104. data/src/core/ext/transport/chttp2/transport/writing.cc +34 -20
  105. data/src/core/ext/transport/inproc/inproc_transport.cc +16 -12
  106. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +117 -0
  107. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +482 -0
  108. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +121 -0
  109. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +553 -0
  110. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +182 -176
  111. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +1248 -685
  112. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +56 -0
  113. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +151 -0
  114. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +62 -0
  115. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +160 -0
  116. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +46 -0
  117. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +124 -0
  118. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +43 -0
  119. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +102 -0
  120. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +43 -0
  121. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +97 -0
  122. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +106 -0
  123. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +605 -0
  124. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +48 -0
  125. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +103 -0
  126. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +14 -12
  127. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +49 -16
  128. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +13 -11
  129. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +49 -23
  130. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +98 -96
  131. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +669 -386
  132. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +185 -173
  133. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1269 -664
  134. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +34 -26
  135. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +200 -91
  136. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +252 -238
  137. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1670 -827
  138. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +10 -8
  139. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +42 -24
  140. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +49 -27
  141. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +272 -99
  142. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +299 -0
  143. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +1381 -0
  144. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +54 -50
  145. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +354 -190
  146. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +11 -8
  147. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +45 -25
  148. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +157 -154
  149. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +1068 -582
  150. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +87 -42
  151. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +525 -167
  152. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +9 -7
  153. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +38 -24
  154. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +11 -29
  155. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +41 -101
  156. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +58 -0
  157. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +151 -0
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +108 -104
  159. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +768 -410
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +115 -84
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +736 -349
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +11 -9
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +57 -31
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +162 -108
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +992 -397
  166. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +8 -6
  167. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +28 -17
  168. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +15 -13
  169. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +83 -49
  170. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +13 -11
  171. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +75 -34
  172. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +15 -13
  173. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +93 -49
  174. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +11 -9
  175. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +46 -26
  176. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +34 -32
  177. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +194 -109
  178. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +51 -48
  179. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +349 -190
  180. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +49 -47
  181. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +357 -188
  182. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +9 -7
  183. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +34 -21
  184. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +72 -61
  185. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +504 -260
  186. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +77 -69
  187. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +560 -301
  188. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +19 -15
  189. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +104 -49
  190. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +12 -10
  191. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +66 -41
  192. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +53 -0
  193. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +136 -0
  194. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +58 -55
  195. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +413 -235
  196. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +62 -60
  197. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +406 -237
  198. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +82 -76
  199. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +562 -294
  200. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +37 -31
  201. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +271 -142
  202. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +503 -475
  203. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +3642 -1901
  204. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +25 -19
  205. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +148 -72
  206. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +222 -0
  207. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +1052 -0
  208. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +44 -0
  209. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +88 -0
  210. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +49 -0
  211. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +103 -0
  212. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +15 -13
  213. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +77 -46
  214. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +52 -0
  215. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +134 -0
  216. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +63 -0
  217. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +250 -0
  218. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +47 -0
  219. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +94 -0
  220. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +69 -0
  221. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +213 -0
  222. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +32 -0
  223. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +42 -0
  224. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +71 -0
  225. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +218 -0
  226. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +54 -0
  227. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +146 -0
  228. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +8 -6
  229. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +34 -24
  230. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +29 -27
  231. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +188 -113
  232. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +36 -34
  233. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +260 -132
  234. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +17 -14
  235. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +86 -49
  236. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +16 -14
  237. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +86 -43
  238. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +229 -198
  239. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1553 -734
  240. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +3 -1
  241. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +2 -1
  242. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +87 -58
  243. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +554 -235
  244. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +26 -24
  245. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +156 -87
  246. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +98 -71
  247. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +622 -263
  248. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +62 -0
  249. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +160 -0
  250. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +6 -4
  251. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +22 -16
  252. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +67 -65
  253. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +474 -256
  254. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +18 -16
  255. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +107 -62
  256. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +51 -49
  257. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +347 -186
  258. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +48 -0
  259. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +112 -0
  260. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +20 -18
  261. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +124 -82
  262. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +74 -0
  263. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +214 -0
  264. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +16 -14
  265. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +99 -57
  266. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +10 -8
  267. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +50 -31
  268. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +10 -8
  269. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +48 -27
  270. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +9 -7
  271. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +38 -24
  272. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +21 -19
  273. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +117 -69
  274. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +19 -17
  275. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +123 -65
  276. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +14 -12
  277. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +85 -53
  278. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +23 -21
  279. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +150 -83
  280. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +32 -30
  281. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +230 -146
  282. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +36 -34
  283. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +235 -131
  284. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +66 -0
  285. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +201 -0
  286. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +3 -1
  287. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +2 -1
  288. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +42 -0
  289. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +139 -0
  290. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +13 -11
  291. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +62 -36
  292. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +19 -17
  293. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +98 -52
  294. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +26 -0
  295. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +41 -0
  296. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +10 -8
  297. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +40 -19
  298. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +51 -0
  299. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +127 -0
  300. data/src/core/ext/upb-generated/google/api/annotations.upb.c +8 -6
  301. data/src/core/ext/upb-generated/google/api/annotations.upb.h +22 -6
  302. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +109 -103
  303. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +720 -382
  304. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +120 -112
  305. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +795 -402
  306. data/src/core/ext/upb-generated/google/api/http.upb.c +29 -27
  307. data/src/core/ext/upb-generated/google/api/http.upb.h +216 -115
  308. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +46 -0
  309. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +111 -0
  310. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +9 -7
  311. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +38 -22
  312. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +291 -237
  313. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +2076 -1030
  314. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +9 -7
  315. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +36 -20
  316. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +6 -4
  317. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +22 -16
  318. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +31 -29
  319. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +177 -93
  320. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +9 -7
  321. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +36 -20
  322. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +40 -38
  323. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +240 -149
  324. data/src/core/ext/upb-generated/google/rpc/status.upb.c +11 -9
  325. data/src/core/ext/upb-generated/google/rpc/status.upb.h +52 -30
  326. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +84 -0
  327. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +319 -0
  328. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +21 -19
  329. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +103 -48
  330. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +102 -96
  331. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +685 -359
  332. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +16 -13
  333. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +76 -41
  334. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +12 -10
  335. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +56 -35
  336. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +57 -55
  337. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +383 -219
  338. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +22 -20
  339. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +115 -63
  340. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +175 -0
  341. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +764 -0
  342. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +36 -34
  343. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +189 -78
  344. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +14 -12
  345. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +53 -22
  346. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +7 -5
  347. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +15 -6
  348. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +14 -12
  349. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +55 -24
  350. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +13 -11
  351. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +49 -23
  352. data/src/core/ext/upb-generated/validate/validate.upb.c +339 -312
  353. data/src/core/ext/upb-generated/validate/validate.upb.h +2726 -1180
  354. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +110 -0
  355. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +278 -0
  356. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +55 -0
  357. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +108 -0
  358. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +38 -0
  359. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +46 -0
  360. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +34 -32
  361. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +171 -80
  362. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +53 -0
  363. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +99 -0
  364. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +8 -6
  365. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +30 -19
  366. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +18 -16
  367. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +98 -55
  368. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +14 -12
  369. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +53 -30
  370. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +46 -0
  371. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +103 -0
  372. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +12 -10
  373. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +55 -30
  374. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +20 -18
  375. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +130 -70
  376. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +12 -10
  377. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +58 -30
  378. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +23 -21
  379. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +101 -46
  380. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +207 -0
  381. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +878 -0
  382. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +52 -0
  383. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +143 -0
  384. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +65 -0
  385. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +218 -0
  386. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +10 -8
  387. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +42 -24
  388. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +84 -0
  389. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +55 -0
  390. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +127 -0
  391. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +50 -0
  392. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +14 -12
  393. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +67 -67
  394. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +43 -0
  395. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +40 -0
  396. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +53 -0
  397. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +40 -0
  398. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +49 -0
  399. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +35 -0
  400. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +46 -0
  401. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +35 -0
  402. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +46 -0
  403. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +35 -0
  404. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +142 -0
  405. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +40 -0
  406. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +51 -0
  407. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +35 -0
  408. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +8 -6
  409. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +1 -1
  410. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +8 -6
  411. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +4 -4
  412. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +20 -17
  413. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +46 -46
  414. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +248 -240
  415. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +55 -55
  416. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +58 -51
  417. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +10 -10
  418. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +385 -371
  419. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +76 -76
  420. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +14 -11
  421. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +4 -4
  422. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +23 -16
  423. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +4 -4
  424. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +206 -0
  425. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +105 -0
  426. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +15 -13
  427. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +22 -22
  428. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +15 -12
  429. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +4 -4
  430. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +85 -80
  431. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +73 -73
  432. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +138 -101
  433. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +26 -16
  434. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +14 -12
  435. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +4 -4
  436. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +22 -34
  437. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +4 -9
  438. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +53 -0
  439. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +40 -0
  440. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +21 -18
  441. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +43 -43
  442. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +177 -166
  443. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +30 -25
  444. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +14 -12
  445. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +4 -4
  446. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +250 -221
  447. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +53 -43
  448. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +12 -9
  449. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +4 -4
  450. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +14 -11
  451. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +7 -7
  452. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +14 -11
  453. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +4 -4
  454. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +18 -15
  455. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +4 -4
  456. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +13 -11
  457. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +4 -4
  458. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +18 -15
  459. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +13 -13
  460. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +19 -16
  461. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +19 -19
  462. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +18 -15
  463. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +16 -16
  464. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +14 -11
  465. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +4 -4
  466. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +52 -45
  467. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +19 -19
  468. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +153 -147
  469. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +22 -22
  470. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +19 -16
  471. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +4 -4
  472. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +15 -12
  473. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +7 -7
  474. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +69 -0
  475. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +35 -0
  476. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +17 -14
  477. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +25 -25
  478. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +17 -14
  479. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +28 -28
  480. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +23 -21
  481. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +25 -25
  482. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +36 -27
  483. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +10 -10
  484. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +826 -803
  485. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +160 -160
  486. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +52 -37
  487. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +10 -10
  488. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +188 -0
  489. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +85 -0
  490. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +54 -0
  491. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +35 -0
  492. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +57 -0
  493. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +35 -0
  494. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +15 -12
  495. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +7 -7
  496. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +72 -0
  497. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +35 -0
  498. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +99 -0
  499. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +35 -0
  500. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +52 -0
  501. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +35 -0
  502. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +71 -0
  503. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +40 -0
  504. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +57 -0
  505. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +30 -0
  506. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +75 -0
  507. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +40 -0
  508. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +77 -0
  509. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +35 -0
  510. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +15 -11
  511. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +4 -4
  512. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +17 -14
  513. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +16 -16
  514. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +18 -15
  515. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +10 -10
  516. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +14 -11
  517. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +7 -7
  518. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +17 -13
  519. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +4 -4
  520. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +197 -172
  521. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +63 -58
  522. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +15 -11
  523. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +1 -1
  524. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +169 -140
  525. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +24 -19
  526. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +19 -16
  527. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +10 -10
  528. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +217 -199
  529. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +24 -19
  530. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +58 -0
  531. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +40 -0
  532. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +14 -11
  533. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +4 -4
  534. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +17 -14
  535. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +22 -22
  536. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +16 -13
  537. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +7 -7
  538. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +20 -17
  539. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +16 -16
  540. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +46 -0
  541. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +35 -0
  542. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +13 -10
  543. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +13 -13
  544. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +52 -0
  545. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +50 -0
  546. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +15 -12
  547. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +7 -7
  548. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +15 -12
  549. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +4 -4
  550. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +15 -12
  551. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +4 -4
  552. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +15 -12
  553. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +4 -4
  554. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +15 -12
  555. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +10 -10
  556. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +15 -12
  557. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +7 -7
  558. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +14 -12
  559. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +7 -7
  560. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +16 -13
  561. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +10 -10
  562. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +13 -10
  563. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +22 -22
  564. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +14 -11
  565. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +16 -16
  566. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +53 -0
  567. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +45 -0
  568. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +10 -8
  569. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +1 -1
  570. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +94 -0
  571. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +35 -0
  572. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +12 -10
  573. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +7 -7
  574. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +11 -8
  575. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +10 -10
  576. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +38 -0
  577. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +30 -0
  578. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +11 -9
  579. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +4 -4
  580. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +57 -0
  581. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +35 -0
  582. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +5 -5
  583. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +1 -1
  584. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +6 -6
  585. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +40 -40
  586. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +6 -6
  587. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +43 -43
  588. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +3 -3
  589. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +10 -10
  590. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +39 -0
  591. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +35 -0
  592. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +3 -3
  593. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +4 -4
  594. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +3 -3
  595. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +82 -82
  596. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +3 -3
  597. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +4 -4
  598. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +3 -3
  599. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +4 -4
  600. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +3 -3
  601. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +13 -13
  602. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +3 -3
  603. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +4 -4
  604. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +3 -3
  605. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +28 -28
  606. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +4 -4
  607. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +4 -4
  608. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +67 -0
  609. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +50 -0
  610. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +99 -0
  611. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +75 -0
  612. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +4 -4
  613. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +10 -10
  614. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +5 -5
  615. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +4 -4
  616. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +4 -4
  617. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +1 -1
  618. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +4 -4
  619. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +4 -4
  620. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +4 -4
  621. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +4 -4
  622. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +6 -6
  623. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +70 -70
  624. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +63 -0
  625. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +45 -0
  626. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +47 -0
  627. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +35 -0
  628. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +35 -0
  629. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +30 -0
  630. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +4 -4
  631. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +13 -13
  632. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +40 -0
  633. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +35 -0
  634. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +5 -5
  635. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +4 -4
  636. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +7 -7
  637. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +7 -7
  638. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +4 -4
  639. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +7 -7
  640. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +41 -0
  641. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +35 -0
  642. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +6 -6
  643. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +4 -4
  644. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +6 -6
  645. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +7 -7
  646. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +6 -6
  647. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +4 -4
  648. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +126 -0
  649. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +80 -0
  650. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +40 -0
  651. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +40 -0
  652. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +52 -0
  653. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +40 -0
  654. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +5 -5
  655. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +4 -4
  656. data/src/core/ext/xds/certificate_provider_store.cc +8 -0
  657. data/src/core/ext/xds/certificate_provider_store.h +9 -0
  658. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +4 -4
  659. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +2 -2
  660. data/src/core/ext/xds/upb_utils.h +8 -6
  661. data/src/core/ext/xds/xds_api.cc +72 -35
  662. data/src/core/ext/xds/xds_api.h +4 -4
  663. data/src/core/ext/xds/xds_bootstrap.cc +37 -5
  664. data/src/core/ext/xds/xds_bootstrap.h +13 -0
  665. data/src/core/ext/xds/xds_certificate_provider.cc +2 -0
  666. data/src/core/ext/xds/xds_certificate_provider.h +8 -0
  667. data/src/core/ext/xds/xds_channel_stack_modifier.cc +14 -17
  668. data/src/core/ext/xds/xds_channel_stack_modifier.h +4 -3
  669. data/src/core/ext/xds/xds_client.cc +220 -193
  670. data/src/core/ext/xds/xds_client.h +35 -19
  671. data/src/core/ext/xds/xds_client_stats.cc +15 -15
  672. data/src/core/ext/xds/xds_client_stats.h +5 -4
  673. data/src/core/ext/xds/xds_cluster.cc +18 -16
  674. data/src/core/ext/xds/xds_cluster.h +3 -6
  675. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +142 -0
  676. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +79 -0
  677. data/src/core/ext/xds/xds_common_types.cc +10 -10
  678. data/src/core/ext/xds/xds_common_types.h +8 -23
  679. data/src/core/ext/xds/xds_endpoint.cc +14 -7
  680. data/src/core/ext/xds/xds_endpoint.h +1 -1
  681. data/src/core/ext/xds/xds_http_fault_filter.cc +7 -7
  682. data/src/core/ext/xds/xds_http_fault_filter.h +3 -3
  683. data/src/core/ext/xds/xds_http_filters.cc +6 -5
  684. data/src/core/ext/xds/xds_http_filters.h +4 -4
  685. data/src/core/ext/xds/xds_http_rbac_filter.cc +5 -5
  686. data/src/core/ext/xds/xds_http_rbac_filter.h +3 -3
  687. data/src/core/ext/xds/xds_listener.cc +15 -12
  688. data/src/core/ext/xds/xds_listener.h +1 -1
  689. data/src/core/ext/xds/xds_resource_type.h +1 -1
  690. data/src/core/ext/xds/xds_route_config.cc +175 -46
  691. data/src/core/ext/xds/xds_route_config.h +14 -11
  692. data/src/core/ext/xds/xds_routing.cc +1 -1
  693. data/src/core/ext/xds/xds_server_config_fetcher.cc +20 -24
  694. data/src/core/lib/avl/avl.h +68 -5
  695. data/src/core/lib/backoff/backoff.cc +7 -10
  696. data/src/core/lib/backoff/backoff.h +8 -8
  697. data/src/core/lib/channel/call_finalization.h +86 -0
  698. data/src/core/lib/channel/call_tracer.h +4 -1
  699. data/src/core/lib/channel/channel_args.cc +161 -22
  700. data/src/core/lib/channel/channel_args.h +210 -7
  701. data/src/core/lib/channel/channel_args_preconditioning.cc +3 -8
  702. data/src/core/lib/channel/channel_args_preconditioning.h +1 -2
  703. data/src/core/lib/channel/channel_stack.cc +2 -3
  704. data/src/core/lib/channel/channel_stack.h +38 -5
  705. data/src/core/lib/channel/channel_stack_builder.cc +23 -266
  706. data/src/core/lib/channel/channel_stack_builder.h +118 -146
  707. data/src/core/lib/channel/channel_stack_builder_impl.cc +102 -0
  708. data/src/core/lib/channel/channel_stack_builder_impl.h +48 -0
  709. data/src/core/lib/channel/channel_trace.cc +3 -6
  710. data/src/core/lib/channel/connected_channel.cc +9 -4
  711. data/src/core/lib/channel/connected_channel.h +2 -1
  712. data/src/core/lib/channel/context.h +11 -0
  713. data/src/core/lib/channel/handshaker.cc +1 -1
  714. data/src/core/lib/channel/handshaker.h +1 -1
  715. data/src/core/lib/channel/promise_based_filter.cc +1002 -0
  716. data/src/core/lib/channel/promise_based_filter.h +437 -0
  717. data/src/core/lib/compression/compression.cc +1 -1
  718. data/src/core/lib/compression/compression_internal.cc +2 -8
  719. data/src/core/lib/config/core_configuration.cc +8 -2
  720. data/src/core/lib/config/core_configuration.h +39 -0
  721. data/src/core/lib/debug/stats_data.cc +2 -6
  722. data/src/core/lib/debug/stats_data.h +18 -21
  723. data/src/core/{ext/filters/max_age/max_age_filter.h → lib/event_engine/default_event_engine_factory.cc} +11 -10
  724. data/src/core/lib/event_engine/event_engine.cc +23 -8
  725. data/src/core/lib/event_engine/event_engine_factory.h +3 -0
  726. data/src/core/lib/event_engine/memory_allocator.cc +9 -13
  727. data/src/core/lib/event_engine/{event_engine_factory.cc → resolved_address.cc} +10 -20
  728. data/src/core/lib/gpr/sync_posix.cc +1 -0
  729. data/src/core/lib/gpr/time.cc +2 -1
  730. data/src/core/lib/gpr/tls.h +1 -0
  731. data/src/core/lib/gpr/useful.h +14 -0
  732. data/src/core/lib/gprpp/bitset.h +12 -0
  733. data/src/core/lib/gprpp/capture.h +76 -0
  734. data/src/core/lib/gprpp/cpp_impl_of.h +4 -0
  735. data/src/core/lib/gprpp/debug_location.h +2 -0
  736. data/src/core/lib/gprpp/match.h +73 -0
  737. data/src/core/lib/gprpp/overload.h +59 -0
  738. data/src/core/lib/gprpp/ref_counted.h +2 -0
  739. data/src/core/lib/gprpp/single_set_ptr.h +87 -0
  740. data/src/core/lib/gprpp/status_helper.cc +30 -14
  741. data/src/core/lib/gprpp/status_helper.h +4 -4
  742. data/src/core/lib/gprpp/time.cc +198 -0
  743. data/src/core/lib/gprpp/time.h +292 -0
  744. data/src/core/lib/http/format_request.cc +28 -25
  745. data/src/core/lib/http/format_request.h +7 -6
  746. data/src/core/lib/http/httpcli.cc +306 -229
  747. data/src/core/lib/http/httpcli.h +182 -77
  748. data/src/core/lib/http/httpcli_security_connector.cc +64 -75
  749. data/src/core/lib/http/httpcli_ssl_credentials.h +37 -0
  750. data/src/core/lib/http/parser.cc +80 -9
  751. data/src/core/lib/http/parser.h +15 -2
  752. data/src/core/lib/iomgr/buffer_list.h +5 -5
  753. data/src/core/lib/iomgr/error.cc +13 -12
  754. data/src/core/lib/iomgr/error.h +0 -5
  755. data/src/core/lib/iomgr/ev_apple.cc +6 -5
  756. data/src/core/lib/iomgr/ev_epoll1_linux.cc +8 -7
  757. data/src/core/lib/iomgr/ev_poll_posix.cc +7 -7
  758. data/src/core/lib/iomgr/ev_posix.cc +9 -10
  759. data/src/core/lib/iomgr/ev_posix.h +1 -1
  760. data/src/core/lib/iomgr/event_engine/pollset.cc +2 -3
  761. data/src/core/lib/iomgr/event_engine/resolver.cc +1 -1
  762. data/src/core/lib/iomgr/event_engine/tcp.cc +4 -3
  763. data/src/core/lib/iomgr/event_engine/timer.cc +3 -4
  764. data/src/core/lib/iomgr/exec_ctx.cc +3 -88
  765. data/src/core/lib/iomgr/exec_ctx.h +7 -23
  766. data/src/core/lib/iomgr/fork_posix.cc +1 -1
  767. data/src/core/lib/iomgr/iocp_windows.cc +9 -9
  768. data/src/core/lib/iomgr/iocp_windows.h +1 -1
  769. data/src/core/lib/iomgr/polling_entity.h +6 -0
  770. data/src/core/lib/iomgr/pollset.cc +1 -1
  771. data/src/core/lib/iomgr/pollset.h +4 -4
  772. data/src/core/lib/iomgr/pollset_windows.cc +2 -2
  773. data/src/core/lib/iomgr/port.h +4 -9
  774. data/src/core/lib/iomgr/resolve_address_posix.cc +1 -1
  775. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +62 -0
  776. data/src/core/lib/iomgr/socket_utils_common_posix.cc +0 -17
  777. data/src/core/lib/iomgr/tcp_client.cc +1 -1
  778. data/src/core/lib/iomgr/tcp_client.h +3 -2
  779. data/src/core/lib/iomgr/tcp_client_cfstream.cc +1 -1
  780. data/src/core/lib/iomgr/tcp_client_posix.cc +4 -4
  781. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  782. data/src/core/lib/iomgr/tcp_client_windows.cc +1 -1
  783. data/src/core/lib/iomgr/tcp_posix.cc +95 -36
  784. data/src/core/lib/iomgr/tcp_server_posix.cc +26 -17
  785. data/src/core/lib/iomgr/tcp_windows.cc +17 -10
  786. data/src/core/lib/iomgr/timer.cc +2 -2
  787. data/src/core/lib/iomgr/timer.h +11 -6
  788. data/src/core/lib/iomgr/timer_generic.cc +96 -77
  789. data/src/core/lib/iomgr/timer_manager.cc +15 -14
  790. data/src/core/lib/iomgr/work_serializer.cc +15 -10
  791. data/src/core/lib/json/json_util.cc +4 -4
  792. data/src/core/lib/json/json_util.h +5 -5
  793. data/src/core/lib/promise/activity.cc +14 -8
  794. data/src/core/lib/promise/activity.h +143 -131
  795. data/src/core/lib/promise/arena_promise.h +188 -0
  796. data/src/core/lib/promise/call_push_pull.h +144 -0
  797. data/src/core/lib/promise/detail/basic_seq.h +92 -3
  798. data/src/core/lib/promise/detail/promise_factory.h +1 -1
  799. data/src/core/lib/promise/detail/status.h +2 -1
  800. data/src/core/lib/promise/intra_activity_waiter.h +49 -0
  801. data/src/core/lib/promise/latch.h +104 -0
  802. data/src/core/lib/promise/loop.h +34 -8
  803. data/src/core/lib/promise/poll.h +6 -0
  804. data/src/core/lib/promise/promise.h +95 -0
  805. data/src/core/lib/promise/seq.h +19 -1
  806. data/src/core/lib/promise/sleep.cc +74 -0
  807. data/src/core/lib/promise/sleep.h +66 -0
  808. data/src/core/lib/promise/try_seq.h +157 -0
  809. data/src/core/lib/resolver/resolver_factory.h +22 -26
  810. data/src/core/lib/resolver/resolver_registry.cc +98 -137
  811. data/src/core/lib/resolver/resolver_registry.h +59 -33
  812. data/src/core/lib/resource_quota/api.cc +5 -30
  813. data/src/core/lib/resource_quota/api.h +1 -1
  814. data/src/core/lib/resource_quota/memory_quota.cc +118 -94
  815. data/src/core/lib/resource_quota/memory_quota.h +100 -64
  816. data/src/core/lib/resource_quota/resource_quota.h +8 -0
  817. data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
  818. data/src/core/lib/security/authorization/evaluate_args.cc +1 -11
  819. data/src/core/lib/security/authorization/evaluate_args.h +0 -1
  820. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +106 -0
  821. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +50 -0
  822. data/src/core/lib/security/authorization/matchers.cc +5 -5
  823. data/src/core/lib/security/authorization/matchers.h +2 -2
  824. data/src/core/lib/security/authorization/rbac_policy.cc +3 -3
  825. data/src/core/lib/security/authorization/rbac_policy.h +3 -2
  826. data/src/core/lib/security/context/security_context.h +8 -1
  827. data/src/core/lib/security/credentials/alts/alts_credentials.cc +6 -5
  828. data/src/core/lib/security/credentials/alts/alts_credentials.h +10 -0
  829. data/src/core/lib/security/credentials/call_creds_util.cc +87 -0
  830. data/src/core/lib/security/credentials/call_creds_util.h +42 -0
  831. data/src/core/lib/security/credentials/channel_creds_registry.h +97 -0
  832. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +70 -0
  833. data/src/core/lib/security/credentials/composite/composite_credentials.cc +24 -83
  834. data/src/core/lib/security/credentials/composite/composite_credentials.h +23 -11
  835. data/src/core/lib/security/credentials/credentials.cc +2 -3
  836. data/src/core/lib/security/credentials/credentials.h +70 -66
  837. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +46 -27
  838. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -0
  839. data/src/core/lib/security/credentials/external/external_account_credentials.cc +49 -29
  840. data/src/core/lib/security/credentials/external/external_account_credentials.h +4 -3
  841. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +0 -1
  842. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +33 -12
  843. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +1 -0
  844. data/src/core/lib/security/credentials/fake/fake_credentials.cc +23 -28
  845. data/src/core/lib/security/credentials/fake/fake_credentials.h +16 -16
  846. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +19 -9
  847. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +9 -3
  848. data/src/core/lib/security/credentials/iam/iam_credentials.cc +15 -19
  849. data/src/core/lib/security/credentials/iam/iam_credentials.h +14 -9
  850. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +25 -26
  851. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +57 -0
  852. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +23 -23
  853. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +13 -9
  854. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +50 -30
  855. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +1 -1
  856. data/src/core/lib/security/credentials/local/local_credentials.cc +6 -6
  857. data/src/core/lib/security/credentials/local/local_credentials.h +10 -0
  858. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +128 -128
  859. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +57 -28
  860. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +96 -151
  861. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +56 -28
  862. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +6 -4
  863. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +14 -3
  864. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +49 -0
  865. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +8 -0
  866. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +42 -3
  867. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +19 -0
  868. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +66 -86
  869. data/src/core/lib/security/credentials/tls/tls_credentials.cc +9 -6
  870. data/src/core/lib/security/credentials/tls/tls_credentials.h +6 -0
  871. data/src/core/lib/security/credentials/xds/xds_credentials.cc +48 -50
  872. data/src/core/lib/security/credentials/xds/xds_credentials.h +36 -5
  873. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +8 -14
  874. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +1 -1
  875. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +4 -12
  876. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +0 -2
  877. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +6 -16
  878. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +4 -9
  879. data/src/core/lib/security/security_connector/local/local_security_connector.cc +10 -18
  880. data/src/core/lib/security/security_connector/security_connector.cc +3 -11
  881. data/src/core/lib/security/security_connector/security_connector.h +20 -20
  882. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +10 -13
  883. data/src/core/lib/security/security_connector/ssl_utils.cc +15 -7
  884. data/src/core/lib/security/security_connector/ssl_utils.h +8 -3
  885. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +27 -16
  886. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +6 -6
  887. data/src/core/lib/security/transport/auth_filters.h +31 -5
  888. data/src/core/lib/security/transport/client_auth_filter.cc +90 -373
  889. data/src/core/lib/security/transport/secure_endpoint.cc +198 -129
  890. data/src/core/lib/security/transport/secure_endpoint.h +1 -1
  891. data/src/core/lib/security/transport/security_handshaker.cc +20 -10
  892. data/src/core/lib/security/transport/server_auth_filter.cc +1 -0
  893. data/src/core/lib/service_config/service_config.h +6 -51
  894. data/src/core/lib/service_config/{service_config.cc → service_config_impl.cc} +19 -16
  895. data/src/core/lib/service_config/service_config_impl.h +125 -0
  896. data/src/core/lib/service_config/service_config_parser.cc +30 -26
  897. data/src/core/lib/service_config/service_config_parser.h +36 -27
  898. data/src/core/lib/slice/slice.cc +76 -181
  899. data/src/core/lib/slice/slice.h +28 -15
  900. data/src/core/lib/slice/slice_internal.h +12 -30
  901. data/src/core/lib/slice/slice_refcount.cc +18 -0
  902. data/src/core/lib/slice/slice_refcount.h +2 -72
  903. data/src/core/lib/slice/slice_refcount_base.h +16 -120
  904. data/src/core/lib/surface/builtins.cc +6 -6
  905. data/src/core/lib/surface/call.cc +1026 -899
  906. data/src/core/lib/surface/call.h +1 -15
  907. data/src/core/lib/surface/channel.cc +28 -32
  908. data/src/core/lib/surface/channel.h +6 -7
  909. data/src/core/lib/surface/channel_init.cc +2 -3
  910. data/src/core/lib/surface/channel_init.h +3 -7
  911. data/src/core/lib/surface/completion_queue.cc +10 -9
  912. data/src/core/lib/surface/init.cc +78 -7
  913. data/src/core/lib/surface/init.h +0 -2
  914. data/src/core/lib/surface/lame_client.cc +2 -1
  915. data/src/core/lib/surface/server.cc +14 -36
  916. data/src/core/lib/surface/server.h +4 -5
  917. data/src/core/lib/surface/version.cc +2 -2
  918. data/src/core/lib/transport/bdp_estimator.cc +9 -10
  919. data/src/core/lib/transport/bdp_estimator.h +2 -2
  920. data/src/core/lib/transport/byte_stream.cc +2 -0
  921. data/src/core/lib/transport/error_utils.cc +5 -3
  922. data/src/core/lib/transport/error_utils.h +2 -15
  923. data/src/core/lib/transport/metadata_batch.h +286 -104
  924. data/src/core/lib/transport/parsed_metadata.h +33 -17
  925. data/src/core/lib/transport/status_conversion.cc +2 -2
  926. data/src/core/lib/transport/status_conversion.h +1 -1
  927. data/src/core/lib/transport/timeout_encoding.cc +32 -29
  928. data/src/core/lib/transport/timeout_encoding.h +3 -3
  929. data/src/core/lib/transport/transport.cc +3 -1
  930. data/src/core/lib/transport/transport.h +102 -2
  931. data/src/core/lib/transport/transport_impl.h +14 -0
  932. data/src/core/lib/transport/transport_op_string.cc +5 -14
  933. data/src/core/lib/uri/uri_parser.cc +4 -0
  934. data/src/core/lib/uri/uri_parser.h +1 -0
  935. data/src/core/plugin_registry/grpc_plugin_registry.cc +21 -92
  936. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +85 -0
  937. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +26 -21
  938. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +9 -1
  939. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +21 -13
  940. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -2
  941. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +1 -1
  942. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -2
  943. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +2 -2
  944. data/src/core/tsi/local_transport_security.cc +3 -11
  945. data/src/core/tsi/local_transport_security.h +1 -4
  946. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +141 -0
  947. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +81 -0
  948. data/src/core/tsi/ssl_transport_security.cc +127 -39
  949. data/src/core/tsi/ssl_transport_security.h +28 -2
  950. data/src/core/tsi/transport_security_interface.h +2 -0
  951. data/src/ruby/ext/grpc/extconf.rb +1 -1
  952. data/src/ruby/ext/grpc/rb_channel.c +5 -2
  953. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +18 -24
  954. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +27 -36
  955. data/src/ruby/ext/grpc/rb_server.c +7 -4
  956. data/src/ruby/lib/grpc/generic/active_call.rb +7 -1
  957. data/src/ruby/lib/grpc/grpc.rb +1 -1
  958. data/src/ruby/lib/grpc/version.rb +1 -1
  959. data/src/ruby/pb/generate_proto_ruby.sh +1 -0
  960. data/src/ruby/pb/test/client.rb +769 -0
  961. data/src/ruby/pb/test/server.rb +252 -0
  962. data/src/ruby/pb/test/xds_client.rb +415 -0
  963. data/third_party/cares/cares/{ares.h → include/ares.h} +73 -1
  964. data/third_party/cares/cares/{ares_dns.h → include/ares_dns.h} +9 -0
  965. data/third_party/cares/cares/{ares_rules.h → include/ares_rules.h} +0 -0
  966. data/third_party/cares/cares/{ares_version.h → include/ares_version.h} +3 -3
  967. data/third_party/cares/cares/{ares__close_sockets.c → src/lib/ares__close_sockets.c} +2 -2
  968. data/third_party/cares/cares/{ares__get_hostent.c → src/lib/ares__get_hostent.c} +1 -2
  969. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +260 -0
  970. data/third_party/cares/cares/{ares__read_line.c → src/lib/ares__read_line.c} +0 -0
  971. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +264 -0
  972. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +499 -0
  973. data/third_party/cares/cares/{ares__timeval.c → src/lib/ares__timeval.c} +0 -0
  974. data/third_party/cares/cares/src/lib/ares_android.c +444 -0
  975. data/third_party/cares/cares/src/lib/ares_android.h +27 -0
  976. data/third_party/cares/cares/{ares_cancel.c → src/lib/ares_cancel.c} +0 -0
  977. data/third_party/cares/cares/{ares_create_query.c → src/lib/ares_create_query.c} +8 -17
  978. data/third_party/cares/cares/{ares_data.c → src/lib/ares_data.c} +18 -0
  979. data/third_party/cares/cares/{ares_data.h → src/lib/ares_data.h} +2 -0
  980. data/third_party/cares/cares/{ares_destroy.c → src/lib/ares_destroy.c} +0 -0
  981. data/third_party/cares/cares/{ares_expand_name.c → src/lib/ares_expand_name.c} +114 -23
  982. data/third_party/cares/cares/{ares_expand_string.c → src/lib/ares_expand_string.c} +2 -5
  983. data/third_party/cares/cares/{ares_fds.c → src/lib/ares_fds.c} +0 -0
  984. data/third_party/cares/cares/{ares_free_hostent.c → src/lib/ares_free_hostent.c} +6 -4
  985. data/third_party/cares/cares/{ares_free_string.c → src/lib/ares_free_string.c} +0 -0
  986. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +59 -0
  987. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +772 -0
  988. data/third_party/cares/cares/{ares_getenv.c → src/lib/ares_getenv.c} +0 -2
  989. data/third_party/cares/cares/{ares_getenv.h → src/lib/ares_getenv.h} +0 -0
  990. data/third_party/cares/cares/{ares_gethostbyaddr.c → src/lib/ares_gethostbyaddr.c} +2 -9
  991. data/third_party/cares/cares/{ares_gethostbyname.c → src/lib/ares_gethostbyname.c} +25 -20
  992. data/third_party/cares/cares/{ares_getnameinfo.c → src/lib/ares_getnameinfo.c} +4 -10
  993. data/third_party/cares/cares/{ares_getsock.c → src/lib/ares_getsock.c} +0 -0
  994. data/third_party/cares/cares/{ares_inet_net_pton.h → src/lib/ares_inet_net_pton.h} +0 -0
  995. data/third_party/cares/cares/{ares_init.c → src/lib/ares_init.c} +79 -40
  996. data/third_party/cares/cares/{ares_iphlpapi.h → src/lib/ares_iphlpapi.h} +0 -0
  997. data/third_party/cares/cares/{ares_ipv6.h → src/lib/ares_ipv6.h} +7 -0
  998. data/third_party/cares/cares/{ares_library_init.c → src/lib/ares_library_init.c} +7 -2
  999. data/third_party/cares/cares/{ares_library_init.h → src/lib/ares_library_init.h} +1 -1
  1000. data/third_party/cares/cares/{ares_llist.c → src/lib/ares_llist.c} +0 -0
  1001. data/third_party/cares/cares/{ares_llist.h → src/lib/ares_llist.h} +0 -0
  1002. data/third_party/cares/cares/{ares_mkquery.c → src/lib/ares_mkquery.c} +0 -0
  1003. data/third_party/cares/cares/src/lib/ares_nameser.h +482 -0
  1004. data/third_party/cares/cares/{ares_nowarn.c → src/lib/ares_nowarn.c} +0 -0
  1005. data/third_party/cares/cares/{ares_nowarn.h → src/lib/ares_nowarn.h} +0 -0
  1006. data/third_party/cares/cares/{ares_options.c → src/lib/ares_options.c} +0 -0
  1007. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +209 -0
  1008. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +212 -0
  1009. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +199 -0
  1010. data/third_party/cares/cares/{ares_parse_mx_reply.c → src/lib/ares_parse_mx_reply.c} +2 -8
  1011. data/third_party/cares/cares/{ares_parse_naptr_reply.c → src/lib/ares_parse_naptr_reply.c} +2 -13
  1012. data/third_party/cares/cares/{ares_parse_ns_reply.c → src/lib/ares_parse_ns_reply.c} +5 -11
  1013. data/third_party/cares/cares/{ares_parse_ptr_reply.c → src/lib/ares_parse_ptr_reply.c} +53 -46
  1014. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +179 -0
  1015. data/third_party/cares/cares/{ares_parse_srv_reply.c → src/lib/ares_parse_srv_reply.c} +2 -13
  1016. data/third_party/cares/cares/{ares_parse_txt_reply.c → src/lib/ares_parse_txt_reply.c} +3 -9
  1017. data/third_party/cares/cares/{ares_platform.c → src/lib/ares_platform.c} +0 -0
  1018. data/third_party/cares/cares/{ares_platform.h → src/lib/ares_platform.h} +0 -0
  1019. data/third_party/cares/cares/{ares_private.h → src/lib/ares_private.h} +52 -11
  1020. data/third_party/cares/cares/{ares_process.c → src/lib/ares_process.c} +127 -52
  1021. data/third_party/cares/cares/{ares_query.c → src/lib/ares_query.c} +3 -9
  1022. data/third_party/cares/cares/{ares_search.c → src/lib/ares_search.c} +5 -7
  1023. data/third_party/cares/cares/{ares_send.c → src/lib/ares_send.c} +2 -8
  1024. data/third_party/cares/cares/{ares_setup.h → src/lib/ares_setup.h} +4 -1
  1025. data/third_party/cares/cares/{ares_strcasecmp.c → src/lib/ares_strcasecmp.c} +0 -0
  1026. data/third_party/cares/cares/{ares_strcasecmp.h → src/lib/ares_strcasecmp.h} +0 -0
  1027. data/third_party/cares/cares/{ares_strdup.c → src/lib/ares_strdup.c} +0 -0
  1028. data/third_party/cares/cares/{ares_strdup.h → src/lib/ares_strdup.h} +0 -0
  1029. data/third_party/cares/cares/{ares_strerror.c → src/lib/ares_strerror.c} +0 -0
  1030. data/third_party/cares/cares/{ares_strsplit.c → src/lib/ares_strsplit.c} +4 -0
  1031. data/third_party/cares/cares/{ares_strsplit.h → src/lib/ares_strsplit.h} +0 -0
  1032. data/third_party/cares/cares/{ares_timeout.c → src/lib/ares_timeout.c} +0 -0
  1033. data/third_party/cares/cares/{ares_version.c → src/lib/ares_version.c} +0 -0
  1034. data/third_party/cares/cares/{ares_writev.c → src/lib/ares_writev.c} +0 -0
  1035. data/third_party/cares/cares/src/lib/ares_writev.h +36 -0
  1036. data/third_party/cares/cares/{bitncmp.c → src/lib/bitncmp.c} +0 -0
  1037. data/third_party/cares/cares/{bitncmp.h → src/lib/bitncmp.h} +0 -0
  1038. data/third_party/cares/cares/src/lib/config-dos.h +115 -0
  1039. data/third_party/cares/cares/{config-win32.h → src/lib/config-win32.h} +0 -0
  1040. data/third_party/cares/cares/{inet_net_pton.c → src/lib/inet_net_pton.c} +2 -8
  1041. data/third_party/cares/cares/{inet_ntop.c → src/lib/inet_ntop.c} +2 -8
  1042. data/third_party/cares/cares/{setup_once.h → src/lib/setup_once.h} +0 -0
  1043. data/third_party/cares/cares/{windows_port.c → src/lib/windows_port.c} +0 -0
  1044. data/third_party/upb/third_party/utf8_range/naive.c +92 -0
  1045. data/third_party/upb/third_party/utf8_range/range2-neon.c +157 -0
  1046. data/third_party/upb/third_party/utf8_range/range2-sse.c +170 -0
  1047. data/third_party/upb/third_party/utf8_range/utf8_range.h +9 -0
  1048. data/third_party/upb/upb/decode.c +542 -319
  1049. data/third_party/upb/upb/decode.h +43 -17
  1050. data/third_party/upb/upb/decode_fast.c +303 -301
  1051. data/third_party/upb/upb/decode_fast.h +18 -18
  1052. data/third_party/upb/upb/decode_internal.h +73 -56
  1053. data/third_party/upb/upb/def.c +1926 -1078
  1054. data/third_party/upb/upb/def.h +329 -288
  1055. data/third_party/upb/upb/def.hpp +129 -172
  1056. data/third_party/upb/upb/encode.c +208 -175
  1057. data/third_party/upb/upb/encode.h +15 -17
  1058. data/third_party/upb/upb/json_encode.c +776 -0
  1059. data/third_party/upb/upb/json_encode.h +62 -0
  1060. data/third_party/upb/upb/msg.c +142 -124
  1061. data/third_party/upb/upb/msg.h +39 -33
  1062. data/third_party/upb/upb/msg_internal.h +342 -280
  1063. data/third_party/upb/upb/port_def.inc +8 -0
  1064. data/third_party/upb/upb/port_undef.inc +1 -0
  1065. data/third_party/upb/upb/reflection.c +239 -199
  1066. data/third_party/upb/upb/reflection.h +87 -67
  1067. data/third_party/upb/upb/reflection.hpp +6 -6
  1068. data/third_party/upb/upb/table.c +231 -147
  1069. data/third_party/upb/upb/table_internal.h +129 -95
  1070. data/third_party/upb/upb/text_encode.c +113 -90
  1071. data/third_party/upb/upb/text_encode.h +10 -10
  1072. data/third_party/upb/upb/upb.c +111 -72
  1073. data/third_party/upb/upb/upb.h +157 -151
  1074. data/third_party/upb/upb/upb.hpp +31 -28
  1075. data/third_party/upb/upb/upb_internal.h +21 -11
  1076. data/third_party/zlib/crc32.c +966 -292
  1077. data/third_party/zlib/crc32.h +9441 -436
  1078. data/third_party/zlib/deflate.c +78 -30
  1079. data/third_party/zlib/deflate.h +12 -15
  1080. data/third_party/zlib/gzguts.h +3 -2
  1081. data/third_party/zlib/gzlib.c +5 -3
  1082. data/third_party/zlib/gzread.c +5 -7
  1083. data/third_party/zlib/gzwrite.c +25 -13
  1084. data/third_party/zlib/infback.c +2 -1
  1085. data/third_party/zlib/inffast.c +14 -14
  1086. data/third_party/zlib/inflate.c +39 -8
  1087. data/third_party/zlib/inflate.h +3 -2
  1088. data/third_party/zlib/inftrees.c +3 -3
  1089. data/third_party/zlib/trees.c +27 -48
  1090. data/third_party/zlib/zlib.h +123 -100
  1091. data/third_party/zlib/zutil.c +2 -2
  1092. data/third_party/zlib/zutil.h +12 -9
  1093. metadata +337 -185
  1094. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel.h +0 -44
  1095. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +0 -83
  1096. data/src/core/ext/filters/client_idle/client_idle_filter.cc +0 -264
  1097. data/src/core/ext/filters/max_age/max_age_filter.cc +0 -560
  1098. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +0 -122
  1099. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +0 -92
  1100. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +0 -192
  1101. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +0 -52
  1102. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +0 -79
  1103. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +0 -125
  1104. data/src/core/ext/transport/chttp2/transport/chttp2_plugin.cc +0 -36
  1105. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.c +0 -38
  1106. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +0 -64
  1107. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.c +0 -38
  1108. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +0 -64
  1109. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.c +0 -38
  1110. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +0 -64
  1111. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.c +0 -38
  1112. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +0 -64
  1113. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.c +0 -38
  1114. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +0 -64
  1115. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/eval.upb.c +0 -102
  1116. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/eval.upb.h +0 -306
  1117. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/explain.upb.c +0 -56
  1118. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/explain.upb.h +0 -135
  1119. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/value.upb.c +0 -115
  1120. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/value.upb.h +0 -371
  1121. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.c +0 -67
  1122. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.h +0 -35
  1123. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.c +0 -68
  1124. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.h +0 -35
  1125. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.c +0 -67
  1126. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.h +0 -35
  1127. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.c +0 -75
  1128. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.h +0 -35
  1129. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.c +0 -69
  1130. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.h +0 -35
  1131. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/eval.upbdefs.c +0 -58
  1132. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/eval.upbdefs.h +0 -55
  1133. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/explain.upbdefs.c +0 -44
  1134. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/explain.upbdefs.h +0 -40
  1135. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/value.upbdefs.c +0 -75
  1136. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/value.upbdefs.h +0 -55
  1137. data/src/core/ext/xds/xds_channel_creds.cc +0 -108
  1138. data/src/core/ext/xds/xds_channel_creds.h +0 -50
  1139. data/src/core/lib/iomgr/ev_epollex_linux.cc +0 -1654
  1140. data/src/core/lib/iomgr/ev_epollex_linux.h +0 -30
  1141. data/src/core/lib/iomgr/iomgr_custom.cc +0 -82
  1142. data/src/core/lib/iomgr/iomgr_custom.h +0 -49
  1143. data/src/core/lib/iomgr/is_epollexclusive_available.cc +0 -119
  1144. data/src/core/lib/iomgr/is_epollexclusive_available.h +0 -36
  1145. data/src/core/lib/iomgr/pollset_custom.cc +0 -105
  1146. data/src/core/lib/iomgr/pollset_custom.h +0 -37
  1147. data/src/core/lib/iomgr/pollset_set_custom.cc +0 -47
  1148. data/src/core/lib/iomgr/pollset_set_custom.h +0 -26
  1149. data/src/core/lib/iomgr/resolve_address_custom.cc +0 -191
  1150. data/src/core/lib/iomgr/resolve_address_custom.h +0 -126
  1151. data/src/core/lib/iomgr/sys_epoll_wrapper.h +0 -30
  1152. data/src/core/lib/iomgr/tcp_client_custom.cc +0 -146
  1153. data/src/core/lib/iomgr/tcp_custom.cc +0 -350
  1154. data/src/core/lib/iomgr/tcp_custom.h +0 -85
  1155. data/src/core/lib/iomgr/tcp_server_custom.cc +0 -457
  1156. data/src/core/lib/iomgr/timer_custom.cc +0 -96
  1157. data/src/core/lib/iomgr/timer_custom.h +0 -43
  1158. data/src/core/lib/security/authorization/sdk_server_authz_filter.cc +0 -173
  1159. data/src/core/lib/security/authorization/sdk_server_authz_filter.h +0 -67
  1160. data/src/core/lib/slice/slice_intern.cc +0 -269
  1161. data/src/core/lib/slice/slice_utils.h +0 -200
  1162. data/src/core/lib/surface/init_secure.cc +0 -103
  1163. data/third_party/cares/cares/ares_getopt.c +0 -122
  1164. data/third_party/cares/cares/ares_getopt.h +0 -53
  1165. data/third_party/cares/cares/ares_parse_a_reply.c +0 -264
  1166. data/third_party/cares/cares/ares_parse_aaaa_reply.c +0 -264
  1167. data/third_party/cares/cares/ares_parse_soa_reply.c +0 -133
@@ -25,6 +25,7 @@
25
25
  #include "absl/time/clock.h"
26
26
  #include "absl/time/time.h"
27
27
 
28
+ #include "src/core/lib/http/httpcli_ssl_credentials.h"
28
29
  #include "src/core/lib/http/parser.h"
29
30
  #include "src/core/lib/security/credentials/external/aws_external_account_credentials.h"
30
31
  #include "src/core/lib/security/credentials/external/file_external_account_credentials.h"
@@ -238,7 +239,7 @@ std::string ExternalAccountCredentials::debug_string() {
238
239
  void ExternalAccountCredentials::fetch_oauth2(
239
240
  grpc_credentials_metadata_request* metadata_req,
240
241
  grpc_polling_entity* pollent, grpc_iomgr_cb_func response_cb,
241
- grpc_millis deadline) {
242
+ Timestamp deadline) {
242
243
  GPR_ASSERT(ctx_ == nullptr);
243
244
  ctx_ = new HTTPRequestContext(pollent, deadline);
244
245
  metadata_req_ = metadata_req;
@@ -267,15 +268,13 @@ void ExternalAccountCredentials::ExchangeToken(
267
268
  uri.status().ToString())));
268
269
  return;
269
270
  }
270
- grpc_httpcli_request request;
271
- memset(&request, 0, sizeof(grpc_httpcli_request));
272
- request.host = const_cast<char*>(uri->authority().c_str());
273
- request.http.path = gpr_strdup(uri->path().c_str());
271
+ grpc_http_request request;
272
+ memset(&request, 0, sizeof(grpc_http_request));
274
273
  grpc_http_header* headers = nullptr;
275
274
  if (!options_.client_id.empty() && !options_.client_secret.empty()) {
276
- request.http.hdr_count = 2;
275
+ request.hdr_count = 2;
277
276
  headers = static_cast<grpc_http_header*>(
278
- gpr_malloc(sizeof(grpc_http_header) * request.http.hdr_count));
277
+ gpr_malloc(sizeof(grpc_http_header) * request.hdr_count));
279
278
  headers[0].key = gpr_strdup("Content-Type");
280
279
  headers[0].value = gpr_strdup("application/x-www-form-urlencoded");
281
280
  std::string raw_cred =
@@ -287,15 +286,13 @@ void ExternalAccountCredentials::ExchangeToken(
287
286
  headers[1].value = gpr_strdup(str.c_str());
288
287
  gpr_free(encoded_cred);
289
288
  } else {
290
- request.http.hdr_count = 1;
289
+ request.hdr_count = 1;
291
290
  headers = static_cast<grpc_http_header*>(
292
- gpr_malloc(sizeof(grpc_http_header) * request.http.hdr_count));
291
+ gpr_malloc(sizeof(grpc_http_header) * request.hdr_count));
293
292
  headers[0].key = gpr_strdup("Content-Type");
294
293
  headers[0].value = gpr_strdup("application/x-www-form-urlencoded");
295
294
  }
296
- request.http.hdrs = headers;
297
- request.handshaker =
298
- uri->scheme() == "https" ? &grpc_httpcli_ssl : &grpc_httpcli_plaintext;
295
+ request.hdrs = headers;
299
296
  std::vector<std::string> body_parts;
300
297
  body_parts.push_back(
301
298
  absl::StrFormat("audience=%s", UrlEncode(options_.audience).c_str()));
@@ -323,13 +320,26 @@ void ExternalAccountCredentials::ExchangeToken(
323
320
  body_parts.push_back(absl::StrFormat(
324
321
  "options=%s", UrlEncode(addtional_options_json.Dump()).c_str()));
325
322
  std::string body = absl::StrJoin(body_parts, "&");
323
+ request.body = const_cast<char*>(body.c_str());
324
+ request.body_length = body.size();
326
325
  grpc_http_response_destroy(&ctx_->response);
327
326
  ctx_->response = {};
328
327
  GRPC_CLOSURE_INIT(&ctx_->closure, OnExchangeToken, this, nullptr);
329
- grpc_httpcli_post(ctx_->pollent, ResourceQuota::Default(), &request,
330
- body.c_str(), body.size(), ctx_->deadline, &ctx_->closure,
331
- &ctx_->response);
332
- grpc_http_request_destroy(&request.http);
328
+ GPR_ASSERT(http_request_ == nullptr);
329
+ RefCountedPtr<grpc_channel_credentials> http_request_creds;
330
+ if (uri->scheme() == "http") {
331
+ http_request_creds = RefCountedPtr<grpc_channel_credentials>(
332
+ grpc_insecure_credentials_create());
333
+ } else {
334
+ http_request_creds = CreateHttpRequestSSLCredentials();
335
+ }
336
+ http_request_ =
337
+ HttpRequest::Post(std::move(*uri), nullptr /* channel args */,
338
+ ctx_->pollent, &request, ctx_->deadline, &ctx_->closure,
339
+ &ctx_->response, std::move(http_request_creds));
340
+ http_request_->Start();
341
+ request.body = nullptr;
342
+ grpc_http_request_destroy(&request);
333
343
  }
334
344
 
335
345
  void ExternalAccountCredentials::OnExchangeToken(void* arg,
@@ -341,6 +351,7 @@ void ExternalAccountCredentials::OnExchangeToken(void* arg,
341
351
 
342
352
  void ExternalAccountCredentials::OnExchangeTokenInternal(
343
353
  grpc_error_handle error) {
354
+ http_request_.reset();
344
355
  if (error != GRPC_ERROR_NONE) {
345
356
  FinishTokenFetch(error);
346
357
  } else {
@@ -390,31 +401,39 @@ void ExternalAccountCredentials::ImpersenateServiceAccount() {
390
401
  options_.service_account_impersonation_url, uri.status().ToString())));
391
402
  return;
392
403
  }
393
- grpc_httpcli_request request;
394
- memset(&request, 0, sizeof(grpc_httpcli_request));
395
- request.host = const_cast<char*>(uri->authority().c_str());
396
- request.http.path = gpr_strdup(uri->path().c_str());
397
- request.http.hdr_count = 2;
404
+ grpc_http_request request;
405
+ memset(&request, 0, sizeof(grpc_http_request));
406
+ request.hdr_count = 2;
398
407
  grpc_http_header* headers = static_cast<grpc_http_header*>(
399
- gpr_malloc(sizeof(grpc_http_header) * request.http.hdr_count));
408
+ gpr_malloc(sizeof(grpc_http_header) * request.hdr_count));
400
409
  headers[0].key = gpr_strdup("Content-Type");
401
410
  headers[0].value = gpr_strdup("application/x-www-form-urlencoded");
402
411
  std::string str = absl::StrFormat("Bearer %s", access_token);
403
412
  headers[1].key = gpr_strdup("Authorization");
404
413
  headers[1].value = gpr_strdup(str.c_str());
405
- request.http.hdrs = headers;
406
- request.handshaker =
407
- uri->scheme() == "https" ? &grpc_httpcli_ssl : &grpc_httpcli_plaintext;
414
+ request.hdrs = headers;
408
415
  std::string scope = absl::StrJoin(scopes_, " ");
409
416
  std::string body = absl::StrFormat("scope=%s", scope);
417
+ request.body = const_cast<char*>(body.c_str());
418
+ request.body_length = body.size();
410
419
  grpc_http_response_destroy(&ctx_->response);
411
420
  ctx_->response = {};
412
421
  GRPC_CLOSURE_INIT(&ctx_->closure, OnImpersenateServiceAccount, this, nullptr);
413
422
  // TODO(ctiller): Use the callers resource quota.
414
- grpc_httpcli_post(ctx_->pollent, ResourceQuota::Default(), &request,
415
- body.c_str(), body.size(), ctx_->deadline, &ctx_->closure,
416
- &ctx_->response);
417
- grpc_http_request_destroy(&request.http);
423
+ GPR_ASSERT(http_request_ == nullptr);
424
+ RefCountedPtr<grpc_channel_credentials> http_request_creds;
425
+ if (uri->scheme() == "http") {
426
+ http_request_creds = RefCountedPtr<grpc_channel_credentials>(
427
+ grpc_insecure_credentials_create());
428
+ } else {
429
+ http_request_creds = CreateHttpRequestSSLCredentials();
430
+ }
431
+ http_request_ = HttpRequest::Post(
432
+ std::move(*uri), nullptr, ctx_->pollent, &request, ctx_->deadline,
433
+ &ctx_->closure, &ctx_->response, std::move(http_request_creds));
434
+ http_request_->Start();
435
+ request.body = nullptr;
436
+ grpc_http_request_destroy(&request);
418
437
  }
419
438
 
420
439
  void ExternalAccountCredentials::OnImpersenateServiceAccount(
@@ -426,6 +445,7 @@ void ExternalAccountCredentials::OnImpersenateServiceAccount(
426
445
 
427
446
  void ExternalAccountCredentials::OnImpersenateServiceAccountInternal(
428
447
  grpc_error_handle error) {
448
+ http_request_.reset();
429
449
  if (error != GRPC_ERROR_NONE) {
430
450
  FinishTokenFetch(error);
431
451
  return;
@@ -61,14 +61,14 @@ class ExternalAccountCredentials
61
61
  // This is a helper struct to pass information between multiple callback based
62
62
  // asynchronous calls.
63
63
  struct HTTPRequestContext {
64
- HTTPRequestContext(grpc_polling_entity* pollent, grpc_millis deadline)
64
+ HTTPRequestContext(grpc_polling_entity* pollent, Timestamp deadline)
65
65
  : pollent(pollent), deadline(deadline) {}
66
66
  ~HTTPRequestContext() { grpc_http_response_destroy(&response); }
67
67
 
68
68
  // Contextual parameters passed from
69
69
  // grpc_oauth2_token_fetcher_credentials::fetch_oauth2().
70
70
  grpc_polling_entity* pollent;
71
- grpc_millis deadline;
71
+ Timestamp deadline;
72
72
 
73
73
  // Reusable token fetch http response and closure.
74
74
  grpc_closure closure;
@@ -89,7 +89,7 @@ class ExternalAccountCredentials
89
89
  // when grpc_oauth2_token_fetcher_credentials request a new access token.
90
90
  void fetch_oauth2(grpc_credentials_metadata_request* req,
91
91
  grpc_polling_entity* pollent, grpc_iomgr_cb_func cb,
92
- grpc_millis deadline) override;
92
+ Timestamp deadline) override;
93
93
 
94
94
  void OnRetrieveSubjectTokenInternal(absl::string_view subject_token,
95
95
  grpc_error_handle error);
@@ -107,6 +107,7 @@ class ExternalAccountCredentials
107
107
  Options options_;
108
108
  std::vector<std::string> scopes_;
109
109
 
110
+ OrphanablePtr<HttpRequest> http_request_;
110
111
  HTTPRequestContext* ctx_ = nullptr;
111
112
  grpc_credentials_metadata_request* metadata_req_ = nullptr;
112
113
  grpc_iomgr_cb_func response_cb_ = nullptr;
@@ -21,7 +21,6 @@
21
21
 
22
22
  #include "src/core/lib/iomgr/load_file.h"
23
23
  #include "src/core/lib/slice/slice_internal.h"
24
- #include "src/core/lib/slice/slice_utils.h"
25
24
 
26
25
  namespace grpc_core {
27
26
 
@@ -21,6 +21,9 @@
21
21
  #include "absl/strings/str_format.h"
22
22
  #include "absl/strings/str_split.h"
23
23
 
24
+ #include "src/core/lib/http/httpcli_ssl_credentials.h"
25
+ #include "src/core/lib/transport/error_utils.h"
26
+
24
27
  namespace grpc_core {
25
28
 
26
29
  RefCountedPtr<UrlExternalAccountCredentials>
@@ -120,31 +123,48 @@ void UrlExternalAccountCredentials::RetrieveSubjectToken(
120
123
  "Missing HTTPRequestContext to start subject token retrieval."));
121
124
  return;
122
125
  }
126
+ auto url_for_request =
127
+ URI::Create(url_.scheme(), url_.authority(), url_full_path_,
128
+ {} /* query params */, "" /* fragment */);
129
+ if (!url_for_request.ok()) {
130
+ FinishRetrieveSubjectToken(
131
+ "", absl_status_to_grpc_error(url_for_request.status()));
132
+ return;
133
+ }
123
134
  ctx_ = ctx;
124
135
  cb_ = cb;
125
- grpc_httpcli_request request;
126
- memset(&request, 0, sizeof(grpc_httpcli_request));
127
- request.host = const_cast<char*>(url_.authority().c_str());
128
- request.http.path = gpr_strdup(url_full_path_.c_str());
136
+ grpc_http_request request;
137
+ memset(&request, 0, sizeof(grpc_http_request));
138
+ request.path = gpr_strdup(url_full_path_.c_str());
129
139
  grpc_http_header* headers = nullptr;
130
- request.http.hdr_count = headers_.size();
140
+ request.hdr_count = headers_.size();
131
141
  headers = static_cast<grpc_http_header*>(
132
- gpr_malloc(sizeof(grpc_http_header) * request.http.hdr_count));
142
+ gpr_malloc(sizeof(grpc_http_header) * request.hdr_count));
133
143
  int i = 0;
134
144
  for (auto const& header : headers_) {
135
145
  headers[i].key = gpr_strdup(header.first.c_str());
136
146
  headers[i].value = gpr_strdup(header.second.c_str());
137
147
  ++i;
138
148
  }
139
- request.http.hdrs = headers;
140
- request.handshaker =
141
- url_.scheme() == "https" ? &grpc_httpcli_ssl : &grpc_httpcli_plaintext;
149
+ request.hdrs = headers;
142
150
  grpc_http_response_destroy(&ctx_->response);
143
151
  ctx_->response = {};
144
152
  GRPC_CLOSURE_INIT(&ctx_->closure, OnRetrieveSubjectToken, this, nullptr);
145
- grpc_httpcli_get(ctx_->pollent, ResourceQuota::Default(), &request,
146
- ctx_->deadline, &ctx_->closure, &ctx_->response);
147
- grpc_http_request_destroy(&request.http);
153
+ GPR_ASSERT(http_request_ == nullptr);
154
+ RefCountedPtr<grpc_channel_credentials> http_request_creds;
155
+ if (url_.scheme() == "http") {
156
+ http_request_creds = RefCountedPtr<grpc_channel_credentials>(
157
+ grpc_insecure_credentials_create());
158
+ } else {
159
+ http_request_creds = RefCountedPtr<grpc_channel_credentials>(
160
+ CreateHttpRequestSSLCredentials());
161
+ }
162
+ http_request_ =
163
+ HttpRequest::Get(std::move(*url_for_request), nullptr /* channel args */,
164
+ ctx_->pollent, &request, ctx_->deadline, &ctx_->closure,
165
+ &ctx_->response, std::move(http_request_creds));
166
+ http_request_->Start();
167
+ grpc_http_request_destroy(&request);
148
168
  }
149
169
 
150
170
  void UrlExternalAccountCredentials::OnRetrieveSubjectToken(
@@ -156,6 +176,7 @@ void UrlExternalAccountCredentials::OnRetrieveSubjectToken(
156
176
 
157
177
  void UrlExternalAccountCredentials::OnRetrieveSubjectTokenInternal(
158
178
  grpc_error_handle error) {
179
+ http_request_.reset();
159
180
  if (error != GRPC_ERROR_NONE) {
160
181
  FinishRetrieveSubjectToken("", error);
161
182
  return;
@@ -51,6 +51,7 @@ class UrlExternalAccountCredentials final : public ExternalAccountCredentials {
51
51
  std::string format_type_;
52
52
  std::string format_subject_token_field_name_;
53
53
 
54
+ OrphanablePtr<HttpRequest> http_request_;
54
55
  HTTPRequestContext* ctx_ = nullptr;
55
56
  std::function<void(std::string, grpc_error_handle)> cb_ = nullptr;
56
57
  };
@@ -29,6 +29,7 @@
29
29
  #include "src/core/lib/channel/channel_args.h"
30
30
  #include "src/core/lib/gpr/string.h"
31
31
  #include "src/core/lib/iomgr/executor.h"
32
+ #include "src/core/lib/promise/promise.h"
32
33
  #include "src/core/lib/security/security_connector/fake/fake_security_connector.h"
33
34
 
34
35
  /* -- Fake transport security credentials. -- */
@@ -36,11 +37,6 @@
36
37
  namespace {
37
38
  class grpc_fake_channel_credentials final : public grpc_channel_credentials {
38
39
  public:
39
- grpc_fake_channel_credentials()
40
- : grpc_channel_credentials(
41
- GRPC_CHANNEL_CREDENTIALS_TYPE_FAKE_TRANSPORT_SECURITY) {}
42
- ~grpc_fake_channel_credentials() override = default;
43
-
44
40
  grpc_core::RefCountedPtr<grpc_channel_security_connector>
45
41
  create_security_connector(
46
42
  grpc_core::RefCountedPtr<grpc_call_credentials> call_creds,
@@ -49,19 +45,25 @@ class grpc_fake_channel_credentials final : public grpc_channel_credentials {
49
45
  return grpc_fake_channel_security_connector_create(
50
46
  this->Ref(), std::move(call_creds), target, args);
51
47
  }
48
+
49
+ const char* type() const override { return "Fake"; }
50
+
51
+ private:
52
+ int cmp_impl(const grpc_channel_credentials* other) const override {
53
+ // TODO(yashykt): Check if we can do something better here
54
+ return grpc_core::QsortCompare(
55
+ static_cast<const grpc_channel_credentials*>(this), other);
56
+ }
52
57
  };
53
58
 
54
59
  class grpc_fake_server_credentials final : public grpc_server_credentials {
55
60
  public:
56
- grpc_fake_server_credentials()
57
- : grpc_server_credentials(
58
- GRPC_CHANNEL_CREDENTIALS_TYPE_FAKE_TRANSPORT_SECURITY) {}
59
- ~grpc_fake_server_credentials() override = default;
60
-
61
61
  grpc_core::RefCountedPtr<grpc_server_security_connector>
62
62
  create_security_connector(const grpc_channel_args* /*args*/) override {
63
63
  return grpc_fake_server_security_connector_create(this->Ref());
64
64
  }
65
+
66
+ const char* type() const override { return "Fake"; }
65
67
  };
66
68
  } // namespace
67
69
 
@@ -89,26 +91,19 @@ const char* grpc_fake_transport_get_expected_targets(
89
91
 
90
92
  /* -- Metadata-only test credentials. -- */
91
93
 
92
- bool grpc_md_only_test_credentials::get_request_metadata(
93
- grpc_polling_entity* /*pollent*/, grpc_auth_metadata_context /*context*/,
94
- grpc_core::CredentialsMetadataArray* md_array,
95
- grpc_closure* on_request_metadata, grpc_error_handle* /*error*/) {
96
- md_array->emplace_back(key_.Ref(), value_.Ref());
97
- if (is_async_) {
98
- grpc_core::ExecCtx::Run(DEBUG_LOCATION, on_request_metadata,
99
- GRPC_ERROR_NONE);
100
- return false;
101
- }
102
- return true;
94
+ grpc_core::ArenaPromise<absl::StatusOr<grpc_core::ClientMetadataHandle>>
95
+ grpc_md_only_test_credentials::GetRequestMetadata(
96
+ grpc_core::ClientMetadataHandle initial_metadata,
97
+ const grpc_call_credentials::GetRequestMetadataArgs*) {
98
+ initial_metadata->Append(
99
+ key_.as_string_view(), value_.Ref(),
100
+ [](absl::string_view, const grpc_core::Slice&) { abort(); });
101
+ return grpc_core::Immediate(std::move(initial_metadata));
103
102
  }
104
103
 
105
- void grpc_md_only_test_credentials::cancel_get_request_metadata(
106
- grpc_core::CredentialsMetadataArray* /*md_array*/,
107
- grpc_error_handle error) {
108
- GRPC_ERROR_UNREF(error);
109
- }
104
+ const char* grpc_md_only_test_credentials::Type() { return "MdOnlyTest"; }
110
105
 
111
106
  grpc_call_credentials* grpc_md_only_test_credentials_create(
112
- const char* md_key, const char* md_value, bool is_async) {
113
- return new grpc_md_only_test_credentials(md_key, md_value, is_async);
107
+ const char* md_key, const char* md_value) {
108
+ return new grpc_md_only_test_credentials(md_key, md_value);
114
109
  }
@@ -59,30 +59,30 @@ const char* grpc_fake_transport_get_expected_targets(
59
59
 
60
60
  class grpc_md_only_test_credentials : public grpc_call_credentials {
61
61
  public:
62
- grpc_md_only_test_credentials(const char* md_key, const char* md_value,
63
- bool is_async)
64
- : grpc_call_credentials(GRPC_CALL_CREDENTIALS_TYPE_OAUTH2,
65
- GRPC_SECURITY_NONE),
62
+ grpc_md_only_test_credentials(const char* md_key, const char* md_value)
63
+ : grpc_call_credentials(GRPC_SECURITY_NONE),
66
64
  key_(grpc_core::Slice::FromCopiedString(md_key)),
67
- value_(grpc_core::Slice::FromCopiedString(md_value)),
68
- is_async_(is_async) {}
65
+ value_(grpc_core::Slice::FromCopiedString(md_value)) {}
69
66
 
70
- bool get_request_metadata(grpc_polling_entity* pollent,
71
- grpc_auth_metadata_context context,
72
- grpc_core::CredentialsMetadataArray* md_array,
73
- grpc_closure* on_request_metadata,
74
- grpc_error_handle* error) override;
67
+ grpc_core::ArenaPromise<absl::StatusOr<grpc_core::ClientMetadataHandle>>
68
+ GetRequestMetadata(grpc_core::ClientMetadataHandle initial_metadata,
69
+ const GetRequestMetadataArgs* args) override;
75
70
 
76
- void cancel_get_request_metadata(
77
- grpc_core::CredentialsMetadataArray* md_array,
78
- grpc_error_handle error) override;
71
+ std::string debug_string() override { return "MD only Test Credentials"; }
79
72
 
80
- std::string debug_string() override { return "MD only Test Credentials"; };
73
+ static const char* Type();
74
+
75
+ const char* type() const override { return Type(); }
81
76
 
82
77
  private:
78
+ int cmp_impl(const grpc_call_credentials* other) const override {
79
+ // TODO(yashykt): Check if we can do something better here
80
+ return grpc_core::QsortCompare(
81
+ static_cast<const grpc_call_credentials*>(this), other);
82
+ }
83
+
83
84
  grpc_core::Slice key_;
84
85
  grpc_core::Slice value_;
85
- bool is_async_;
86
86
  };
87
87
 
88
88
  #endif /* GRPC_CORE_LIB_SECURITY_CREDENTIALS_FAKE_FAKE_CREDENTIALS_H */
@@ -138,6 +138,10 @@ grpc_channel_args* grpc_google_default_channel_credentials::update_arguments(
138
138
  return updated;
139
139
  }
140
140
 
141
+ const char* grpc_google_default_channel_credentials::type() const {
142
+ return "GoogleDefault";
143
+ }
144
+
141
145
  static void on_metadata_server_detection_http_response(
142
146
  void* user_data, grpc_error_handle error) {
143
147
  metadata_server_detector* detector =
@@ -171,26 +175,31 @@ static void destroy_pollset(void* p, grpc_error_handle /*e*/) {
171
175
 
172
176
  static int is_metadata_server_reachable() {
173
177
  metadata_server_detector detector;
174
- grpc_httpcli_request request;
178
+ grpc_http_request request;
175
179
  grpc_closure destroy_closure;
176
180
  /* The http call is local. If it takes more than one sec, it is for sure not
177
181
  on compute engine. */
178
- grpc_millis max_detection_delay = GPR_MS_PER_SEC;
182
+ const auto max_detection_delay = grpc_core::Duration::Seconds(1);
179
183
  grpc_pollset* pollset =
180
184
  static_cast<grpc_pollset*>(gpr_zalloc(grpc_pollset_size()));
181
185
  grpc_pollset_init(pollset, &g_polling_mu);
182
186
  detector.pollent = grpc_polling_entity_create_from_pollset(pollset);
183
187
  detector.is_done = 0;
184
188
  detector.success = 0;
185
- memset(&request, 0, sizeof(grpc_httpcli_request));
186
- request.host = const_cast<char*>(GRPC_COMPUTE_ENGINE_DETECTION_HOST);
187
- request.http.path = const_cast<char*>("/");
188
- grpc_httpcli_get(
189
- &detector.pollent, grpc_core::ResourceQuota::Default(), &request,
189
+ memset(&request, 0, sizeof(grpc_http_request));
190
+ auto uri =
191
+ grpc_core::URI::Create("http", GRPC_COMPUTE_ENGINE_DETECTION_HOST, "/",
192
+ {} /* query params */, "" /* fragment */);
193
+ GPR_ASSERT(uri.ok()); // params are hardcoded
194
+ auto http_request = grpc_core::HttpRequest::Get(
195
+ std::move(*uri), nullptr /* channel args */, &detector.pollent, &request,
190
196
  grpc_core::ExecCtx::Get()->Now() + max_detection_delay,
191
197
  GRPC_CLOSURE_CREATE(on_metadata_server_detection_http_response, &detector,
192
198
  grpc_schedule_on_exec_ctx),
193
- &detector.response);
199
+ &detector.response,
200
+ grpc_core::RefCountedPtr<grpc_channel_credentials>(
201
+ grpc_insecure_credentials_create()));
202
+ http_request->Start();
194
203
  grpc_core::ExecCtx::Get()->Flush();
195
204
  /* Block until we get the response. This is not ideal but this should only be
196
205
  called once for the lifetime of the process by the default credentials. */
@@ -200,12 +209,13 @@ static int is_metadata_server_reachable() {
200
209
  if (!GRPC_LOG_IF_ERROR(
201
210
  "pollset_work",
202
211
  grpc_pollset_work(grpc_polling_entity_pollset(&detector.pollent),
203
- &worker, GRPC_MILLIS_INF_FUTURE))) {
212
+ &worker, grpc_core::Timestamp::InfFuture()))) {
204
213
  detector.is_done = 1;
205
214
  detector.success = 0;
206
215
  }
207
216
  }
208
217
  gpr_mu_unlock(g_polling_mu);
218
+ http_request.reset();
209
219
  GRPC_CLOSURE_INIT(&destroy_closure, destroy_pollset,
210
220
  grpc_polling_entity_pollset(&detector.pollent),
211
221
  grpc_schedule_on_exec_ctx);
@@ -46,9 +46,7 @@ class grpc_google_default_channel_credentials
46
46
  grpc_google_default_channel_credentials(
47
47
  grpc_core::RefCountedPtr<grpc_channel_credentials> alts_creds,
48
48
  grpc_core::RefCountedPtr<grpc_channel_credentials> ssl_creds)
49
- : grpc_channel_credentials(GRPC_CHANNEL_CREDENTIALS_TYPE_GOOGLE_DEFAULT),
50
- alts_creds_(std::move(alts_creds)),
51
- ssl_creds_(std::move(ssl_creds)) {}
49
+ : alts_creds_(std::move(alts_creds)), ssl_creds_(std::move(ssl_creds)) {}
52
50
 
53
51
  ~grpc_google_default_channel_credentials() override = default;
54
52
 
@@ -60,12 +58,20 @@ class grpc_google_default_channel_credentials
60
58
 
61
59
  grpc_channel_args* update_arguments(grpc_channel_args* args) override;
62
60
 
61
+ const char* type() const override;
62
+
63
63
  const grpc_channel_credentials* alts_creds() const {
64
64
  return alts_creds_.get();
65
65
  }
66
66
  const grpc_channel_credentials* ssl_creds() const { return ssl_creds_.get(); }
67
67
 
68
68
  private:
69
+ int cmp_impl(const grpc_channel_credentials* other) const override {
70
+ // TODO(yashykt): Check if we can do something better here
71
+ return grpc_core::QsortCompare(
72
+ static_cast<const grpc_channel_credentials*>(this), other);
73
+ }
74
+
69
75
  grpc_core::RefCountedPtr<grpc_channel_credentials> alts_creds_;
70
76
  grpc_core::RefCountedPtr<grpc_channel_credentials> ssl_creds_;
71
77
  };
@@ -28,33 +28,27 @@
28
28
  #include <grpc/support/sync.h>
29
29
 
30
30
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
31
+ #include "src/core/lib/promise/promise.h"
31
32
  #include "src/core/lib/surface/api_trace.h"
32
33
 
33
- bool grpc_google_iam_credentials::get_request_metadata(
34
- grpc_polling_entity* /*pollent*/, grpc_auth_metadata_context /*context*/,
35
- grpc_core::CredentialsMetadataArray* md_array,
36
- grpc_closure* /*on_request_metadata*/, grpc_error_handle* /*error*/) {
34
+ grpc_core::ArenaPromise<absl::StatusOr<grpc_core::ClientMetadataHandle>>
35
+ grpc_google_iam_credentials::GetRequestMetadata(
36
+ grpc_core::ClientMetadataHandle initial_metadata,
37
+ const grpc_call_credentials::GetRequestMetadataArgs*) {
37
38
  if (token_.has_value()) {
38
- md_array->emplace_back(grpc_core::Slice::FromStaticString(
39
- GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY),
40
- token_->Ref());
39
+ initial_metadata->Append(
40
+ GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY, token_->Ref(),
41
+ [](absl::string_view, const grpc_core::Slice&) { abort(); });
41
42
  }
42
- md_array->emplace_back(grpc_core::Slice::FromStaticString(
43
- GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY),
44
- authority_selector_.Ref());
45
- return true;
46
- }
47
-
48
- void grpc_google_iam_credentials::cancel_get_request_metadata(
49
- grpc_core::CredentialsMetadataArray* /*md_array*/,
50
- grpc_error_handle error) {
51
- GRPC_ERROR_UNREF(error);
43
+ initial_metadata->Append(
44
+ GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY, authority_selector_.Ref(),
45
+ [](absl::string_view, const grpc_core::Slice&) { abort(); });
46
+ return grpc_core::Immediate(std::move(initial_metadata));
52
47
  }
53
48
 
54
49
  grpc_google_iam_credentials::grpc_google_iam_credentials(
55
50
  const char* token, const char* authority_selector)
56
- : grpc_call_credentials(GRPC_CALL_CREDENTIALS_TYPE_IAM),
57
- token_(token == nullptr ? absl::optional<grpc_core::Slice>()
51
+ : token_(token == nullptr ? absl::optional<grpc_core::Slice>()
58
52
  : grpc_core::Slice::FromCopiedString(token)),
59
53
  authority_selector_(
60
54
  grpc_core::Slice::FromCopiedString(authority_selector)),
@@ -62,6 +56,8 @@ grpc_google_iam_credentials::grpc_google_iam_credentials(
62
56
  "GoogleIAMCredentials{Token:%s,AuthoritySelector:%s}",
63
57
  token != nullptr ? "present" : "absent", authority_selector)) {}
64
58
 
59
+ const char* grpc_google_iam_credentials::Type() { return "Iam"; }
60
+
65
61
  grpc_call_credentials* grpc_google_iam_credentials_create(
66
62
  const char* token, const char* authority_selector, void* reserved) {
67
63
  grpc_core::ExecCtx exec_ctx;
@@ -30,18 +30,23 @@ class grpc_google_iam_credentials : public grpc_call_credentials {
30
30
  grpc_google_iam_credentials(const char* token,
31
31
  const char* authority_selector);
32
32
 
33
- bool get_request_metadata(grpc_polling_entity* pollent,
34
- grpc_auth_metadata_context context,
35
- grpc_core::CredentialsMetadataArray* md_array,
36
- grpc_closure* on_request_metadata,
37
- grpc_error_handle* error) override;
38
-
39
- void cancel_get_request_metadata(
40
- grpc_core::CredentialsMetadataArray* md_array,
41
- grpc_error_handle error) override;
33
+ grpc_core::ArenaPromise<absl::StatusOr<grpc_core::ClientMetadataHandle>>
34
+ GetRequestMetadata(grpc_core::ClientMetadataHandle initial_metadata,
35
+ const GetRequestMetadataArgs* args) override;
36
+
42
37
  std::string debug_string() override { return debug_string_; }
43
38
 
39
+ static const char* Type();
40
+
41
+ const char* type() const override { return Type(); }
42
+
44
43
  private:
44
+ int cmp_impl(const grpc_call_credentials* other) const override {
45
+ // TODO(yashykt): Check if we can do something better here
46
+ return grpc_core::QsortCompare(
47
+ static_cast<const grpc_call_credentials*>(this), other);
48
+ }
49
+
45
50
  const absl::optional<grpc_core::Slice> token_;
46
51
  const grpc_core::Slice authority_selector_;
47
52
  const std::string debug_string_;