grpc 1.43.1 → 1.45.0

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

Potentially problematic release.


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

Files changed (1240) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +349 -216
  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 +36 -50
  7. data/include/grpc/impl/codegen/compression_types.h +0 -2
  8. data/include/grpc/impl/codegen/grpc_types.h +17 -8
  9. data/include/grpc/impl/codegen/port_platform.h +2 -2
  10. data/include/grpc/impl/codegen/slice.h +4 -1
  11. data/include/grpc/slice.h +0 -11
  12. data/src/core/ext/filters/client_channel/backend_metric.cc +3 -3
  13. data/src/core/ext/filters/client_channel/backend_metric.h +1 -1
  14. data/src/core/ext/filters/client_channel/backup_poller.cc +12 -8
  15. data/src/core/ext/filters/client_channel/channel_connectivity.cc +5 -5
  16. data/src/core/ext/filters/client_channel/client_channel.cc +140 -124
  17. data/src/core/ext/filters/client_channel/client_channel.h +38 -37
  18. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +6 -12
  19. data/src/core/ext/filters/client_channel/config_selector.h +4 -4
  20. data/src/core/ext/filters/client_channel/connector.h +1 -1
  21. data/src/core/ext/filters/client_channel/dynamic_filters.cc +1 -2
  22. data/src/core/ext/filters/client_channel/dynamic_filters.h +2 -2
  23. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +2 -22
  24. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +3 -15
  25. data/src/core/ext/filters/client_channel/health/health_check_client.cc +32 -31
  26. data/src/core/ext/filters/client_channel/health/health_check_client.h +4 -4
  27. data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +10 -13
  28. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +4 -3
  29. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +6 -5
  30. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +4 -7
  31. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +99 -79
  32. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.h +0 -7
  33. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +1 -1
  34. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +15 -15
  35. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +4 -4
  36. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +50 -32
  37. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +28 -19
  38. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +120 -68
  39. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +161 -112
  40. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +62 -61
  41. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +16 -11
  42. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +13 -7
  43. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +28 -19
  44. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +1 -1
  45. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +65 -36
  46. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +5 -3
  47. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +69 -117
  48. data/src/core/ext/filters/client_channel/lb_policy.cc +15 -14
  49. data/src/core/ext/filters/client_channel/lb_policy.h +19 -3
  50. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +10 -16
  51. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +259 -120
  52. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +22 -12
  53. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +19 -15
  54. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +23 -38
  55. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +136 -226
  56. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +25 -32
  57. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
  58. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +120 -113
  59. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +18 -17
  60. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +2 -1
  61. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +83 -61
  62. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +40 -39
  63. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +185 -96
  64. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +8 -11
  65. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +13 -7
  66. data/src/core/ext/filters/client_channel/retry_filter.cc +236 -169
  67. data/src/core/ext/filters/client_channel/retry_service_config.cc +16 -18
  68. data/src/core/ext/filters/client_channel/retry_service_config.h +18 -12
  69. data/src/core/ext/filters/client_channel/retry_throttle.cc +9 -23
  70. data/src/core/ext/filters/client_channel/retry_throttle.h +11 -5
  71. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +8 -7
  72. data/src/core/ext/filters/client_channel/subchannel.cc +45 -52
  73. data/src/core/ext/filters/client_channel/subchannel.h +7 -7
  74. data/src/core/ext/filters/client_idle/client_idle_filter.cc +96 -159
  75. data/src/core/ext/filters/client_idle/idle_filter_state.h +2 -2
  76. data/src/core/ext/filters/deadline/deadline_filter.cc +15 -14
  77. data/src/core/ext/filters/deadline/deadline_filter.h +3 -2
  78. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +53 -58
  79. data/src/core/ext/filters/fault_injection/service_config_parser.cc +11 -13
  80. data/src/core/ext/filters/fault_injection/service_config_parser.h +10 -4
  81. data/src/core/ext/filters/http/client/http_client_filter.cc +58 -125
  82. data/src/core/ext/filters/http/client_authority_filter.cc +28 -87
  83. data/src/core/ext/filters/http/client_authority_filter.h +23 -5
  84. data/src/core/ext/filters/http/http_filters_plugin.cc +11 -12
  85. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +43 -140
  86. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +15 -27
  87. data/src/core/ext/filters/http/server/http_server_filter.cc +51 -135
  88. data/src/core/ext/filters/max_age/max_age_filter.cc +46 -40
  89. data/src/core/ext/filters/message_size/message_size_filter.cc +27 -35
  90. data/src/core/ext/filters/message_size/message_size_filter.h +10 -3
  91. data/src/core/ext/filters/rbac/rbac_filter.cc +162 -0
  92. data/src/core/ext/filters/rbac/rbac_filter.h +76 -0
  93. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +606 -0
  94. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +75 -0
  95. data/src/core/ext/filters/server_config_selector/server_config_selector.h +3 -2
  96. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +12 -6
  97. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +234 -0
  98. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +236 -34
  99. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +155 -233
  100. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +8 -2
  101. data/src/core/ext/transport/chttp2/transport/flow_control.cc +2 -2
  102. data/src/core/ext/transport/chttp2/transport/flow_control.h +3 -3
  103. data/src/core/ext/transport/chttp2/transport/frame_data.cc +0 -1
  104. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +4 -4
  105. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +5 -0
  106. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +342 -281
  107. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +70 -160
  108. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +1 -1
  109. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +2 -0
  110. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +29 -78
  111. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +0 -1
  112. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +94 -1
  113. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +2 -24
  114. data/src/core/ext/transport/chttp2/transport/internal.h +6 -39
  115. data/src/core/ext/transport/chttp2/transport/parsing.cc +3 -9
  116. data/src/core/ext/transport/chttp2/transport/writing.cc +62 -128
  117. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -4
  118. data/src/core/ext/transport/inproc/inproc_transport.cc +27 -75
  119. data/src/core/ext/transport/inproc/inproc_transport.h +0 -3
  120. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +114 -0
  121. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +402 -0
  122. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +119 -0
  123. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +453 -0
  124. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +165 -163
  125. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +798 -575
  126. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +56 -0
  127. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +138 -0
  128. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +62 -0
  129. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +146 -0
  130. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +46 -0
  131. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +106 -0
  132. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +43 -0
  133. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +93 -0
  134. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +43 -0
  135. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +88 -0
  136. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +103 -0
  137. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +466 -0
  138. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +48 -0
  139. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +95 -0
  140. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +22 -20
  141. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +17 -16
  142. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +15 -13
  143. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +31 -23
  144. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +90 -88
  145. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +421 -317
  146. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +156 -152
  147. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +787 -571
  148. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +27 -25
  149. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +115 -79
  150. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +206 -204
  151. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +954 -662
  152. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +10 -8
  153. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +33 -23
  154. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +29 -27
  155. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +127 -79
  156. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +290 -0
  157. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +1122 -0
  158. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +49 -47
  159. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +221 -159
  160. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +10 -8
  161. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +33 -23
  162. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +154 -151
  163. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +691 -499
  164. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +39 -37
  165. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +178 -130
  166. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +9 -7
  167. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +25 -19
  168. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +18 -16
  169. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +74 -53
  170. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +58 -0
  171. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +138 -0
  172. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +100 -98
  173. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +449 -329
  174. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +77 -75
  175. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +365 -264
  176. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +11 -9
  177. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +36 -26
  178. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +140 -105
  179. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +675 -345
  180. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +8 -6
  181. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +25 -17
  182. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +15 -13
  183. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +59 -42
  184. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +13 -11
  185. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +39 -25
  186. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +14 -12
  187. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +45 -35
  188. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +10 -8
  189. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +34 -24
  190. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +31 -29
  191. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +113 -85
  192. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +47 -45
  193. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +210 -151
  194. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +48 -46
  195. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +210 -142
  196. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +9 -7
  197. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +28 -20
  198. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +58 -54
  199. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +282 -193
  200. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +64 -62
  201. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +286 -218
  202. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +15 -13
  203. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +62 -42
  204. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +12 -10
  205. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +54 -39
  206. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +53 -0
  207. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +120 -0
  208. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +55 -53
  209. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +244 -185
  210. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +57 -55
  211. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +260 -192
  212. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +70 -68
  213. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +235 -191
  214. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +30 -28
  215. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +142 -112
  216. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +435 -428
  217. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +2037 -1507
  218. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +25 -19
  219. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +107 -64
  220. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +216 -0
  221. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +870 -0
  222. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +44 -0
  223. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +82 -0
  224. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +49 -0
  225. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +95 -0
  226. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +15 -13
  227. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +55 -40
  228. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +52 -0
  229. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +119 -0
  230. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +62 -0
  231. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +203 -0
  232. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +47 -0
  233. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +89 -0
  234. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +69 -0
  235. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +184 -0
  236. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +32 -0
  237. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +42 -0
  238. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +71 -0
  239. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +192 -0
  240. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +54 -0
  241. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +126 -0
  242. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +8 -6
  243. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +29 -23
  244. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +26 -24
  245. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +125 -93
  246. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +33 -31
  247. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +149 -105
  248. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +63 -0
  249. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +165 -0
  250. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +15 -13
  251. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +53 -37
  252. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +175 -173
  253. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +803 -559
  254. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +3 -1
  255. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +2 -1
  256. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +75 -52
  257. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +368 -194
  258. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +24 -22
  259. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +95 -71
  260. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +60 -58
  261. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +266 -193
  262. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +62 -0
  263. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +146 -0
  264. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +6 -4
  265. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +22 -16
  266. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +64 -62
  267. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +297 -218
  268. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +18 -16
  269. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +73 -54
  270. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +46 -44
  271. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +197 -145
  272. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +48 -0
  273. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +101 -0
  274. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +19 -17
  275. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +91 -70
  276. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +74 -0
  277. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +202 -0
  278. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +16 -14
  279. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +64 -47
  280. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +10 -8
  281. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +34 -26
  282. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +10 -8
  283. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +25 -19
  284. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +9 -7
  285. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +25 -19
  286. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +21 -19
  287. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +85 -61
  288. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +19 -17
  289. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +65 -52
  290. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +14 -12
  291. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +56 -43
  292. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +21 -19
  293. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +74 -58
  294. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +30 -28
  295. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +163 -125
  296. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +34 -32
  297. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +157 -113
  298. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +66 -0
  299. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +183 -0
  300. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +3 -1
  301. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +2 -1
  302. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +42 -0
  303. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +136 -0
  304. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +13 -11
  305. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +51 -34
  306. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +19 -17
  307. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +80 -52
  308. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +26 -0
  309. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +41 -0
  310. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +10 -8
  311. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +31 -19
  312. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +51 -0
  313. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +114 -0
  314. data/src/core/ext/upb-generated/google/api/annotations.upb.c +10 -8
  315. data/src/core/ext/upb-generated/google/api/annotations.upb.h +6 -5
  316. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +100 -98
  317. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +371 -281
  318. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +110 -108
  319. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +409 -298
  320. data/src/core/ext/upb-generated/google/api/http.upb.c +29 -27
  321. data/src/core/ext/upb-generated/google/api/http.upb.h +117 -89
  322. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +46 -0
  323. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +99 -0
  324. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +9 -7
  325. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +32 -22
  326. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +287 -234
  327. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +1088 -764
  328. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +9 -7
  329. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +28 -18
  330. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +6 -4
  331. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +22 -16
  332. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +30 -28
  333. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +80 -64
  334. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +9 -7
  335. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +28 -18
  336. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +40 -38
  337. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +213 -149
  338. data/src/core/ext/upb-generated/google/rpc/status.upb.c +11 -9
  339. data/src/core/ext/upb-generated/google/rpc/status.upb.h +36 -26
  340. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +84 -0
  341. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +276 -0
  342. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +20 -18
  343. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +60 -42
  344. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +95 -93
  345. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +396 -285
  346. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +15 -13
  347. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +58 -39
  348. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +12 -10
  349. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +50 -35
  350. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +55 -53
  351. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +255 -183
  352. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +22 -20
  353. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +76 -57
  354. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +46 -44
  355. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +102 -78
  356. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +16 -14
  357. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +32 -22
  358. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +9 -7
  359. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +6 -5
  360. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +16 -14
  361. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +32 -22
  362. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +15 -13
  363. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +31 -23
  364. data/src/core/ext/upb-generated/validate/validate.upb.c +320 -304
  365. data/src/core/ext/upb-generated/validate/validate.upb.h +1114 -741
  366. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +110 -0
  367. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +191 -0
  368. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +55 -0
  369. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +87 -0
  370. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +38 -0
  371. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +38 -0
  372. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +40 -38
  373. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +109 -78
  374. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +53 -0
  375. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +81 -0
  376. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +8 -6
  377. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +27 -19
  378. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +17 -15
  379. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +63 -46
  380. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +14 -12
  381. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +31 -25
  382. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +46 -0
  383. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +95 -0
  384. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +11 -9
  385. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +39 -27
  386. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +20 -18
  387. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +73 -54
  388. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +12 -10
  389. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +43 -29
  390. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +23 -21
  391. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +43 -31
  392. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +203 -0
  393. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +726 -0
  394. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +52 -0
  395. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +132 -0
  396. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +65 -0
  397. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +173 -0
  398. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +10 -8
  399. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +33 -23
  400. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +84 -0
  401. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +55 -0
  402. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +127 -0
  403. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +50 -0
  404. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +14 -12
  405. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +67 -67
  406. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +43 -0
  407. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +40 -0
  408. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +53 -0
  409. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +40 -0
  410. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +49 -0
  411. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +35 -0
  412. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +46 -0
  413. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +35 -0
  414. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +46 -0
  415. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +35 -0
  416. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +142 -0
  417. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +40 -0
  418. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +51 -0
  419. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +35 -0
  420. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +8 -6
  421. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +1 -1
  422. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +8 -6
  423. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +4 -4
  424. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +20 -17
  425. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +46 -46
  426. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +248 -240
  427. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +55 -55
  428. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +16 -13
  429. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +10 -10
  430. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +375 -371
  431. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +76 -76
  432. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +14 -11
  433. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +4 -4
  434. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +16 -13
  435. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +4 -4
  436. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +206 -0
  437. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +105 -0
  438. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +15 -13
  439. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +22 -22
  440. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +15 -12
  441. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +4 -4
  442. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +85 -80
  443. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +73 -73
  444. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +18 -16
  445. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +16 -16
  446. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +14 -12
  447. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +4 -4
  448. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +15 -12
  449. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +7 -7
  450. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +53 -0
  451. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +40 -0
  452. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +21 -18
  453. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +43 -43
  454. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +23 -20
  455. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +25 -25
  456. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +14 -12
  457. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +4 -4
  458. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +250 -221
  459. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +53 -43
  460. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +12 -9
  461. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +4 -4
  462. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +14 -11
  463. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +7 -7
  464. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +14 -11
  465. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +4 -4
  466. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +18 -15
  467. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +4 -4
  468. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +13 -11
  469. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +4 -4
  470. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +18 -15
  471. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +13 -13
  472. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +19 -16
  473. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +19 -19
  474. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +18 -15
  475. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +16 -16
  476. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +14 -11
  477. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +4 -4
  478. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +52 -45
  479. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +19 -19
  480. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +23 -20
  481. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +22 -22
  482. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +19 -16
  483. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +4 -4
  484. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +15 -12
  485. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +7 -7
  486. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +69 -0
  487. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +35 -0
  488. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +17 -14
  489. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +25 -25
  490. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +17 -14
  491. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +28 -28
  492. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +190 -0
  493. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +70 -0
  494. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +19 -16
  495. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +10 -10
  496. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +816 -801
  497. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +160 -160
  498. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +52 -37
  499. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +10 -10
  500. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +188 -0
  501. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +85 -0
  502. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +54 -0
  503. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +35 -0
  504. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +57 -0
  505. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +35 -0
  506. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +15 -12
  507. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +7 -7
  508. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +72 -0
  509. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +35 -0
  510. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +99 -0
  511. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +35 -0
  512. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +52 -0
  513. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +35 -0
  514. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +71 -0
  515. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +40 -0
  516. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +57 -0
  517. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +30 -0
  518. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +75 -0
  519. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +40 -0
  520. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +77 -0
  521. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +35 -0
  522. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +15 -11
  523. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +4 -4
  524. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +17 -14
  525. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +16 -16
  526. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +18 -15
  527. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +10 -10
  528. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +59 -0
  529. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +40 -0
  530. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +17 -13
  531. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +4 -4
  532. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +135 -130
  533. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +58 -58
  534. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +15 -11
  535. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +1 -1
  536. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +169 -140
  537. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +24 -19
  538. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +19 -16
  539. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +10 -10
  540. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +21 -17
  541. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +19 -19
  542. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +58 -0
  543. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +40 -0
  544. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +14 -11
  545. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +4 -4
  546. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +17 -14
  547. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +22 -22
  548. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +16 -13
  549. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +7 -7
  550. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +20 -17
  551. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +16 -16
  552. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +46 -0
  553. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +35 -0
  554. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +13 -10
  555. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +13 -13
  556. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +52 -0
  557. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +50 -0
  558. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +15 -12
  559. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +7 -7
  560. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +15 -12
  561. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +4 -4
  562. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +15 -12
  563. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +4 -4
  564. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +15 -12
  565. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +4 -4
  566. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +15 -12
  567. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +10 -10
  568. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +15 -12
  569. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +7 -7
  570. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +14 -12
  571. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +7 -7
  572. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +16 -13
  573. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +10 -10
  574. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +13 -10
  575. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +22 -22
  576. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +14 -11
  577. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +16 -16
  578. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +53 -0
  579. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +45 -0
  580. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +10 -8
  581. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +1 -1
  582. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +94 -0
  583. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +35 -0
  584. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +12 -10
  585. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +7 -7
  586. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +11 -8
  587. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +10 -10
  588. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +38 -0
  589. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +30 -0
  590. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +11 -9
  591. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +4 -4
  592. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +57 -0
  593. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +35 -0
  594. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +5 -5
  595. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +1 -1
  596. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +154 -0
  597. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +95 -0
  598. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +153 -0
  599. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +100 -0
  600. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +3 -3
  601. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +10 -10
  602. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +39 -0
  603. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +35 -0
  604. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +3 -3
  605. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +4 -4
  606. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +3 -3
  607. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +82 -82
  608. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +3 -3
  609. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +4 -4
  610. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +3 -3
  611. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +4 -4
  612. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +3 -3
  613. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +13 -13
  614. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +3 -3
  615. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +4 -4
  616. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +3 -3
  617. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +28 -28
  618. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +4 -4
  619. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +4 -4
  620. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +67 -0
  621. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +50 -0
  622. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +4 -4
  623. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +10 -10
  624. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +5 -5
  625. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +4 -4
  626. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +4 -4
  627. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +1 -1
  628. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +4 -4
  629. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +4 -4
  630. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +4 -4
  631. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +4 -4
  632. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +6 -6
  633. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +70 -70
  634. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +63 -0
  635. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +45 -0
  636. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +47 -0
  637. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +35 -0
  638. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +35 -0
  639. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +30 -0
  640. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +4 -4
  641. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +13 -13
  642. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +40 -0
  643. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +35 -0
  644. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +5 -5
  645. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +4 -4
  646. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +7 -7
  647. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +7 -7
  648. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +4 -4
  649. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +7 -7
  650. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +41 -0
  651. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +35 -0
  652. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +6 -6
  653. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +4 -4
  654. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +6 -6
  655. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +7 -7
  656. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +6 -6
  657. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +4 -4
  658. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +126 -0
  659. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +80 -0
  660. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +40 -0
  661. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +40 -0
  662. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +52 -0
  663. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +40 -0
  664. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +5 -5
  665. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +4 -4
  666. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +4 -4
  667. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +2 -2
  668. data/src/core/ext/xds/upb_utils.h +67 -0
  669. data/src/core/ext/xds/xds_api.cc +127 -3487
  670. data/src/core/ext/xds/xds_api.h +60 -615
  671. data/src/core/ext/xds/xds_bootstrap.cc +221 -125
  672. data/src/core/ext/xds/xds_bootstrap.h +31 -15
  673. data/src/core/ext/xds/xds_certificate_provider.h +1 -0
  674. data/src/core/ext/xds/xds_channel_stack_modifier.cc +14 -17
  675. data/src/core/ext/xds/xds_channel_stack_modifier.h +4 -3
  676. data/src/core/ext/xds/xds_client.cc +702 -1077
  677. data/src/core/ext/xds/xds_client.h +101 -150
  678. data/src/core/ext/xds/xds_client_stats.cc +15 -15
  679. data/src/core/ext/xds/xds_client_stats.h +5 -4
  680. data/src/core/ext/xds/xds_cluster.cc +453 -0
  681. data/src/core/ext/xds/xds_cluster.h +108 -0
  682. data/src/core/ext/xds/xds_common_types.cc +388 -0
  683. data/src/core/ext/xds/xds_common_types.h +95 -0
  684. data/src/core/ext/xds/xds_endpoint.cc +364 -0
  685. data/src/core/ext/xds/xds_endpoint.h +135 -0
  686. data/src/core/ext/xds/xds_http_fault_filter.cc +6 -6
  687. data/src/core/ext/xds/xds_http_fault_filter.h +3 -3
  688. data/src/core/ext/xds/xds_http_filters.cc +11 -5
  689. data/src/core/ext/xds/xds_http_filters.h +4 -4
  690. data/src/core/ext/xds/xds_http_rbac_filter.cc +563 -0
  691. data/src/core/ext/xds/xds_http_rbac_filter.h +54 -0
  692. data/src/core/ext/xds/xds_listener.cc +1039 -0
  693. data/src/core/ext/xds/xds_listener.h +220 -0
  694. data/src/core/ext/{transport/chttp2/transport/hpack_utils.h → xds/xds_resource_type.cc} +12 -9
  695. data/src/core/ext/xds/xds_resource_type.h +98 -0
  696. data/src/core/ext/xds/xds_resource_type_impl.h +87 -0
  697. data/src/core/ext/xds/xds_route_config.cc +985 -0
  698. data/src/core/ext/xds/xds_route_config.h +215 -0
  699. data/src/core/ext/xds/xds_routing.cc +12 -9
  700. data/src/core/ext/xds/xds_routing.h +8 -5
  701. data/src/core/ext/xds/xds_server_config_fetcher.cc +162 -101
  702. data/src/core/lib/address_utils/parse_address.cc +20 -0
  703. data/src/core/lib/address_utils/parse_address.h +5 -0
  704. data/src/core/lib/address_utils/sockaddr_utils.cc +33 -36
  705. data/src/core/lib/address_utils/sockaddr_utils.h +1 -16
  706. data/src/core/lib/backoff/backoff.cc +8 -37
  707. data/src/core/lib/backoff/backoff.h +11 -11
  708. data/src/core/lib/channel/call_finalization.h +86 -0
  709. data/src/core/lib/channel/channel_args.cc +60 -1
  710. data/src/core/lib/channel/channel_args.h +2 -0
  711. data/src/core/lib/channel/channel_args_preconditioning.cc +1 -0
  712. data/src/core/lib/channel/channel_stack.cc +10 -3
  713. data/src/core/lib/channel/channel_stack.h +42 -6
  714. data/src/core/lib/channel/channel_stack_builder.cc +66 -248
  715. data/src/core/lib/channel/channel_stack_builder.h +95 -147
  716. data/src/core/lib/channel/channel_trace.cc +3 -6
  717. data/src/core/lib/channel/channelz.cc +1 -0
  718. data/src/core/lib/channel/connected_channel.cc +9 -4
  719. data/src/core/lib/channel/connected_channel.h +1 -1
  720. data/src/core/lib/channel/context.h +11 -0
  721. data/src/core/lib/channel/handshaker.cc +1 -1
  722. data/src/core/lib/channel/handshaker.h +1 -1
  723. data/src/core/lib/channel/promise_based_filter.cc +669 -0
  724. data/src/core/lib/channel/promise_based_filter.h +423 -0
  725. data/src/core/lib/compression/compression.cc +20 -112
  726. data/src/core/lib/compression/compression_internal.cc +143 -203
  727. data/src/core/lib/compression/compression_internal.h +64 -69
  728. data/src/core/lib/compression/message_compress.cc +11 -11
  729. data/src/core/lib/compression/message_compress.h +2 -2
  730. data/src/core/lib/config/core_configuration.cc +8 -2
  731. data/src/core/lib/config/core_configuration.h +39 -0
  732. data/src/core/lib/event_engine/default_event_engine_factory.cc +27 -0
  733. data/src/core/lib/event_engine/event_engine.cc +23 -8
  734. data/src/core/lib/event_engine/event_engine_factory.h +3 -0
  735. data/src/core/lib/event_engine/memory_allocator.cc +9 -13
  736. data/src/core/lib/event_engine/{event_engine_factory.cc → resolved_address.cc} +10 -20
  737. data/src/core/lib/gpr/sync_posix.cc +1 -0
  738. data/src/core/lib/gpr/time.cc +2 -1
  739. data/src/core/lib/gpr/useful.h +18 -0
  740. data/src/core/lib/gprpp/bitset.h +7 -0
  741. data/src/core/lib/gprpp/capture.h +76 -0
  742. data/src/core/lib/gprpp/chunked_vector.h +45 -3
  743. data/src/core/lib/gprpp/debug_location.h +2 -0
  744. data/src/core/lib/gprpp/status_helper.cc +30 -38
  745. data/src/core/lib/gprpp/status_helper.h +6 -19
  746. data/src/core/lib/gprpp/table.h +11 -0
  747. data/src/core/lib/gprpp/time.cc +186 -0
  748. data/src/core/lib/gprpp/time.h +292 -0
  749. data/src/core/lib/http/format_request.cc +27 -23
  750. data/src/core/lib/http/format_request.h +7 -6
  751. data/src/core/lib/http/httpcli.cc +307 -239
  752. data/src/core/lib/http/httpcli.h +182 -89
  753. data/src/core/lib/http/httpcli_security_connector.cc +62 -73
  754. data/src/core/lib/http/httpcli_ssl_credentials.h +37 -0
  755. data/src/core/lib/http/parser.h +1 -1
  756. data/src/core/lib/iomgr/buffer_list.h +5 -5
  757. data/src/core/lib/iomgr/call_combiner.cc +15 -4
  758. data/src/core/lib/iomgr/closure.h +29 -9
  759. data/src/core/lib/iomgr/combiner.cc +25 -3
  760. data/src/core/lib/iomgr/error.cc +13 -10
  761. data/src/core/lib/iomgr/error.h +0 -2
  762. data/src/core/lib/iomgr/ev_apple.cc +6 -5
  763. data/src/core/lib/iomgr/ev_epoll1_linux.cc +8 -7
  764. data/src/core/lib/iomgr/ev_epollex_linux.cc +12 -9
  765. data/src/core/lib/iomgr/ev_poll_posix.cc +7 -7
  766. data/src/core/lib/iomgr/ev_posix.cc +3 -3
  767. data/src/core/lib/iomgr/ev_posix.h +1 -1
  768. data/src/core/lib/iomgr/event_engine/iomgr.cc +3 -2
  769. data/src/core/lib/iomgr/event_engine/pollset.cc +2 -3
  770. data/src/core/lib/iomgr/event_engine/resolved_address_internal.cc +6 -0
  771. data/src/core/lib/iomgr/event_engine/resolved_address_internal.h +2 -0
  772. data/src/core/lib/iomgr/event_engine/resolver.cc +66 -48
  773. data/src/core/lib/iomgr/event_engine/resolver.h +56 -0
  774. data/src/core/lib/iomgr/event_engine/tcp.cc +4 -3
  775. data/src/core/lib/iomgr/event_engine/timer.cc +3 -4
  776. data/src/core/lib/iomgr/exec_ctx.cc +25 -97
  777. data/src/core/lib/iomgr/exec_ctx.h +7 -23
  778. data/src/core/lib/iomgr/executor.cc +10 -1
  779. data/src/core/lib/iomgr/fork_posix.cc +3 -2
  780. data/src/core/lib/iomgr/iocp_windows.cc +9 -9
  781. data/src/core/lib/iomgr/iocp_windows.h +1 -1
  782. data/src/core/lib/iomgr/iomgr_posix.cc +2 -2
  783. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +2 -2
  784. data/src/core/lib/iomgr/iomgr_windows.cc +2 -2
  785. data/src/core/lib/iomgr/polling_entity.h +6 -0
  786. data/src/core/lib/iomgr/pollset.cc +1 -1
  787. data/src/core/lib/iomgr/pollset.h +4 -4
  788. data/src/core/lib/iomgr/pollset_windows.cc +2 -2
  789. data/src/core/lib/iomgr/port.h +6 -9
  790. data/src/core/lib/iomgr/resolve_address.cc +5 -24
  791. data/src/core/lib/iomgr/resolve_address.h +47 -44
  792. data/src/core/lib/iomgr/resolve_address_impl.h +59 -0
  793. data/src/core/lib/iomgr/resolve_address_posix.cc +83 -67
  794. data/src/core/lib/iomgr/resolve_address_posix.h +47 -0
  795. data/src/core/lib/iomgr/resolve_address_windows.cc +93 -74
  796. data/src/core/lib/iomgr/resolve_address_windows.h +47 -0
  797. data/src/core/lib/iomgr/resolved_address.h +39 -0
  798. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +62 -0
  799. data/src/core/lib/iomgr/socket_utils_common_posix.cc +0 -17
  800. data/src/core/lib/iomgr/tcp_client.cc +1 -1
  801. data/src/core/lib/iomgr/tcp_client.h +3 -2
  802. data/src/core/lib/iomgr/tcp_client_cfstream.cc +1 -1
  803. data/src/core/lib/iomgr/tcp_client_posix.cc +2 -2
  804. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  805. data/src/core/lib/iomgr/tcp_client_windows.cc +1 -1
  806. data/src/core/lib/iomgr/tcp_posix.cc +2 -1
  807. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +1 -0
  808. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +1 -0
  809. data/src/core/lib/iomgr/tcp_windows.cc +17 -10
  810. data/src/core/lib/iomgr/timer.cc +2 -2
  811. data/src/core/lib/iomgr/timer.h +11 -6
  812. data/src/core/lib/iomgr/timer_generic.cc +96 -77
  813. data/src/core/lib/iomgr/timer_manager.cc +15 -14
  814. data/src/core/lib/iomgr/unix_sockets_posix.cc +22 -34
  815. data/src/core/lib/iomgr/unix_sockets_posix.h +4 -7
  816. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +6 -15
  817. data/src/core/lib/iomgr/work_serializer.cc +15 -10
  818. data/src/core/lib/json/json_util.cc +4 -4
  819. data/src/core/lib/json/json_util.h +2 -2
  820. data/src/core/lib/matchers/matchers.cc +1 -1
  821. data/src/core/lib/promise/activity.cc +14 -8
  822. data/src/core/lib/promise/activity.h +183 -142
  823. data/src/core/lib/promise/arena_promise.h +188 -0
  824. data/src/core/lib/promise/detail/basic_seq.h +92 -3
  825. data/src/core/lib/promise/detail/promise_factory.h +1 -1
  826. data/src/core/lib/promise/detail/status.h +5 -0
  827. data/src/core/lib/promise/loop.h +34 -8
  828. data/src/core/lib/promise/poll.h +6 -0
  829. data/src/core/lib/promise/promise.h +95 -0
  830. data/src/core/lib/promise/seq.h +19 -1
  831. data/src/core/lib/promise/sleep.cc +74 -0
  832. data/src/core/lib/promise/sleep.h +66 -0
  833. data/src/core/lib/promise/try_seq.h +157 -0
  834. data/src/core/{ext/filters/client_channel → lib/resolver}/resolver.cc +17 -25
  835. data/src/core/{ext/filters/client_channel → lib/resolver}/resolver.h +43 -44
  836. data/src/core/{ext/filters/client_channel → lib/resolver}/resolver_factory.h +32 -31
  837. data/src/core/lib/resolver/resolver_registry.cc +156 -0
  838. data/src/core/lib/resolver/resolver_registry.h +113 -0
  839. data/src/core/{ext/filters/client_channel → lib/resolver}/server_address.cc +1 -1
  840. data/src/core/{ext/filters/client_channel → lib/resolver}/server_address.h +4 -4
  841. data/src/core/lib/resource_quota/api.h +0 -1
  842. data/src/core/lib/{gprpp → resource_quota}/arena.cc +16 -13
  843. data/src/core/lib/{gprpp → resource_quota}/arena.h +24 -13
  844. data/src/core/lib/resource_quota/memory_quota.cc +118 -94
  845. data/src/core/lib/resource_quota/memory_quota.h +100 -64
  846. data/src/core/lib/security/authorization/evaluate_args.cc +26 -21
  847. data/src/core/lib/security/authorization/evaluate_args.h +1 -1
  848. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +60 -0
  849. data/src/core/lib/security/authorization/grpc_authorization_engine.h +62 -0
  850. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +109 -0
  851. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +51 -0
  852. data/src/core/lib/security/authorization/matchers.cc +227 -0
  853. data/src/core/lib/security/authorization/matchers.h +211 -0
  854. data/src/core/lib/security/authorization/rbac_policy.cc +442 -0
  855. data/src/core/lib/security/authorization/rbac_policy.h +171 -0
  856. data/src/core/lib/security/context/security_context.cc +4 -2
  857. data/src/core/lib/security/context/security_context.h +1 -1
  858. data/src/core/lib/security/credentials/alts/alts_credentials.h +6 -0
  859. data/src/core/lib/security/credentials/call_creds_util.cc +87 -0
  860. data/src/core/lib/security/credentials/call_creds_util.h +42 -0
  861. data/src/core/lib/security/credentials/channel_creds_registry.h +97 -0
  862. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +70 -0
  863. data/src/core/lib/security/credentials/composite/composite_credentials.cc +17 -81
  864. data/src/core/lib/security/credentials/composite/composite_credentials.h +21 -9
  865. data/src/core/lib/security/credentials/credentials.cc +2 -3
  866. data/src/core/lib/security/credentials/credentials.h +68 -57
  867. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +46 -30
  868. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +1 -0
  869. data/src/core/lib/security/credentials/external/external_account_credentials.cc +51 -33
  870. data/src/core/lib/security/credentials/external/external_account_credentials.h +5 -9
  871. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +0 -1
  872. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +33 -13
  873. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +1 -0
  874. data/src/core/lib/security/credentials/fake/fake_credentials.cc +18 -18
  875. data/src/core/lib/security/credentials/fake/fake_credentials.h +14 -16
  876. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +16 -13
  877. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +6 -0
  878. data/src/core/lib/security/credentials/iam/iam_credentials.cc +19 -27
  879. data/src/core/lib/security/credentials/iam/iam_credentials.h +11 -9
  880. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +13 -7
  881. data/src/core/lib/security/credentials/jwt/json_token.cc +4 -6
  882. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +27 -43
  883. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +12 -12
  884. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +54 -41
  885. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +1 -1
  886. data/src/core/lib/security/credentials/local/local_credentials.h +6 -0
  887. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +137 -158
  888. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +52 -33
  889. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +95 -153
  890. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +54 -27
  891. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +1 -10
  892. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +6 -3
  893. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +25 -0
  894. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +17 -1
  895. data/src/core/lib/security/credentials/tls/tls_credentials.h +6 -0
  896. data/src/core/lib/security/credentials/xds/xds_credentials.h +6 -1
  897. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +8 -14
  898. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +1 -1
  899. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +4 -12
  900. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +0 -2
  901. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +6 -16
  902. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +4 -9
  903. data/src/core/lib/security/security_connector/local/local_security_connector.cc +8 -16
  904. data/src/core/lib/security/security_connector/security_connector.cc +3 -15
  905. data/src/core/lib/security/security_connector/security_connector.h +16 -21
  906. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +6 -11
  907. data/src/core/lib/security/security_connector/ssl_utils.cc +29 -31
  908. data/src/core/lib/security/security_connector/ssl_utils.h +13 -17
  909. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -13
  910. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +6 -6
  911. data/src/core/lib/security/transport/auth_filters.h +37 -4
  912. data/src/core/lib/security/transport/client_auth_filter.cc +87 -358
  913. data/src/core/lib/security/transport/security_handshaker.cc +14 -6
  914. data/src/core/lib/security/transport/server_auth_filter.cc +41 -35
  915. data/src/core/lib/service_config/service_config.h +82 -0
  916. data/src/core/{ext → lib}/service_config/service_config_call_data.h +5 -5
  917. data/src/core/{ext/service_config/service_config.cc → lib/service_config/service_config_impl.cc} +20 -17
  918. data/src/core/{ext/service_config/service_config.h → lib/service_config/service_config_impl.h} +16 -18
  919. data/src/core/{ext → lib}/service_config/service_config_parser.cc +31 -27
  920. data/src/core/{ext → lib}/service_config/service_config_parser.h +39 -30
  921. data/src/core/lib/slice/slice.cc +76 -179
  922. data/src/core/lib/slice/slice.h +67 -24
  923. data/src/core/lib/slice/slice_internal.h +12 -31
  924. data/src/core/lib/slice/slice_refcount.cc +18 -0
  925. data/src/core/lib/slice/slice_refcount.h +6 -85
  926. data/src/core/lib/slice/slice_refcount_base.h +16 -136
  927. data/src/core/lib/surface/builtins.cc +6 -6
  928. data/src/core/lib/surface/call.cc +152 -387
  929. data/src/core/lib/surface/call.h +5 -5
  930. data/src/core/lib/surface/channel.cc +64 -71
  931. data/src/core/lib/surface/channel.h +10 -11
  932. data/src/core/lib/surface/channel_init.cc +1 -1
  933. data/src/core/lib/surface/channel_init.h +4 -4
  934. data/src/core/lib/surface/completion_queue.cc +10 -9
  935. data/src/core/lib/surface/init.cc +78 -9
  936. data/src/core/lib/surface/init.h +0 -2
  937. data/src/core/lib/surface/lame_client.cc +2 -2
  938. data/src/core/lib/surface/server.cc +23 -51
  939. data/src/core/lib/surface/server.h +5 -5
  940. data/src/core/lib/surface/version.cc +2 -2
  941. data/src/core/lib/transport/bdp_estimator.cc +9 -10
  942. data/src/core/lib/transport/bdp_estimator.h +2 -2
  943. data/src/core/lib/transport/error_utils.cc +5 -3
  944. data/src/core/lib/transport/error_utils.h +2 -1
  945. data/src/core/lib/transport/metadata_batch.h +1010 -750
  946. data/src/core/lib/transport/parsed_metadata.cc +2 -0
  947. data/src/core/lib/transport/parsed_metadata.h +115 -96
  948. data/src/core/lib/transport/status_conversion.cc +2 -2
  949. data/src/core/lib/transport/status_conversion.h +1 -1
  950. data/src/core/lib/transport/timeout_encoding.cc +204 -67
  951. data/src/core/lib/transport/timeout_encoding.h +40 -10
  952. data/src/core/lib/transport/transport.cc +3 -1
  953. data/src/core/lib/transport/transport.h +88 -3
  954. data/src/core/lib/transport/transport_impl.h +13 -0
  955. data/src/core/lib/transport/transport_op_string.cc +5 -47
  956. data/src/core/lib/uri/uri_parser.cc +227 -53
  957. data/src/core/lib/uri/uri_parser.h +37 -23
  958. data/src/core/plugin_registry/grpc_plugin_registry.cc +19 -87
  959. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +85 -0
  960. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +27 -22
  961. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +9 -1
  962. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +19 -11
  963. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +2 -2
  964. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +1 -1
  965. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -2
  966. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +2 -2
  967. data/src/core/tsi/local_transport_security.cc +3 -11
  968. data/src/core/tsi/local_transport_security.h +1 -4
  969. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +141 -0
  970. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +81 -0
  971. data/src/core/tsi/ssl/session_cache/ssl_session.h +2 -4
  972. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +3 -5
  973. data/src/core/tsi/ssl_transport_security.cc +105 -14
  974. data/src/core/tsi/ssl_transport_security.h +38 -6
  975. data/src/ruby/ext/grpc/extconf.rb +10 -3
  976. data/src/ruby/ext/grpc/rb_channel.c +5 -2
  977. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +20 -24
  978. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +30 -36
  979. data/src/ruby/ext/grpc/rb_server.c +7 -4
  980. data/src/ruby/lib/grpc/version.rb +1 -1
  981. data/src/ruby/pb/src/proto/grpc/testing/test_pb.rb +2 -1
  982. data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +48 -0
  983. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +200 -0
  984. data/third_party/abseil-cpp/absl/random/beta_distribution.h +427 -0
  985. data/third_party/abseil-cpp/absl/random/discrete_distribution.cc +98 -0
  986. data/third_party/abseil-cpp/absl/random/discrete_distribution.h +247 -0
  987. data/third_party/abseil-cpp/absl/random/distributions.h +452 -0
  988. data/third_party/abseil-cpp/absl/random/exponential_distribution.h +165 -0
  989. data/third_party/abseil-cpp/absl/random/gaussian_distribution.cc +104 -0
  990. data/third_party/abseil-cpp/absl/random/gaussian_distribution.h +275 -0
  991. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +92 -0
  992. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +268 -0
  993. data/third_party/abseil-cpp/absl/random/internal/fastmath.h +57 -0
  994. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +144 -0
  995. data/third_party/abseil-cpp/absl/random/internal/iostream_state_saver.h +245 -0
  996. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +150 -0
  997. data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +308 -0
  998. data/third_party/abseil-cpp/absl/random/internal/platform.h +171 -0
  999. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.cc +253 -0
  1000. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.h +131 -0
  1001. data/third_party/abseil-cpp/absl/random/internal/randen.cc +91 -0
  1002. data/third_party/abseil-cpp/absl/random/internal/randen.h +102 -0
  1003. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +221 -0
  1004. data/third_party/abseil-cpp/absl/random/internal/randen_detect.h +33 -0
  1005. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +239 -0
  1006. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.cc +526 -0
  1007. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.h +50 -0
  1008. data/third_party/abseil-cpp/absl/random/internal/randen_round_keys.cc +462 -0
  1009. data/third_party/abseil-cpp/absl/random/internal/randen_slow.cc +471 -0
  1010. data/third_party/abseil-cpp/absl/random/internal/randen_slow.h +40 -0
  1011. data/third_party/abseil-cpp/absl/random/internal/randen_traits.h +88 -0
  1012. data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +167 -0
  1013. data/third_party/abseil-cpp/absl/random/internal/seed_material.cc +267 -0
  1014. data/third_party/abseil-cpp/absl/random/internal/seed_material.h +104 -0
  1015. data/third_party/abseil-cpp/absl/random/internal/traits.h +101 -0
  1016. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +244 -0
  1017. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +111 -0
  1018. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +257 -0
  1019. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +258 -0
  1020. data/third_party/abseil-cpp/absl/random/random.h +189 -0
  1021. data/third_party/abseil-cpp/absl/random/seed_gen_exception.cc +46 -0
  1022. data/third_party/abseil-cpp/absl/random/seed_gen_exception.h +55 -0
  1023. data/third_party/abseil-cpp/absl/random/seed_sequences.cc +29 -0
  1024. data/third_party/abseil-cpp/absl/random/seed_sequences.h +110 -0
  1025. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +275 -0
  1026. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +202 -0
  1027. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +271 -0
  1028. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +1 -0
  1029. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +13 -0
  1030. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +21 -0
  1031. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +12 -0
  1032. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +1 -2
  1033. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +2 -2
  1034. data/third_party/boringssl-with-bazel/src/crypto/mem.c +1 -1
  1035. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +29 -0
  1036. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +0 -1
  1037. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +1 -1
  1038. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +1 -1
  1039. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +8 -0
  1040. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +13 -1
  1041. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +10 -0
  1042. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +1 -1
  1043. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +9 -4
  1044. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +6 -1
  1045. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +23 -2
  1046. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +4 -0
  1047. data/third_party/cares/cares/{ares.h → include/ares.h} +73 -1
  1048. data/third_party/cares/cares/{ares_dns.h → include/ares_dns.h} +9 -0
  1049. data/third_party/cares/cares/{ares_rules.h → include/ares_rules.h} +0 -0
  1050. data/third_party/cares/cares/{ares_version.h → include/ares_version.h} +3 -3
  1051. data/third_party/cares/cares/{ares__close_sockets.c → src/lib/ares__close_sockets.c} +2 -2
  1052. data/third_party/cares/cares/{ares__get_hostent.c → src/lib/ares__get_hostent.c} +1 -2
  1053. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +260 -0
  1054. data/third_party/cares/cares/{ares__read_line.c → src/lib/ares__read_line.c} +0 -0
  1055. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +264 -0
  1056. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +499 -0
  1057. data/third_party/cares/cares/{ares__timeval.c → src/lib/ares__timeval.c} +0 -0
  1058. data/third_party/cares/cares/src/lib/ares_android.c +444 -0
  1059. data/third_party/cares/cares/src/lib/ares_android.h +27 -0
  1060. data/third_party/cares/cares/{ares_cancel.c → src/lib/ares_cancel.c} +0 -0
  1061. data/third_party/cares/cares/{ares_create_query.c → src/lib/ares_create_query.c} +8 -17
  1062. data/third_party/cares/cares/{ares_data.c → src/lib/ares_data.c} +18 -0
  1063. data/third_party/cares/cares/{ares_data.h → src/lib/ares_data.h} +2 -0
  1064. data/third_party/cares/cares/{ares_destroy.c → src/lib/ares_destroy.c} +0 -0
  1065. data/third_party/cares/cares/{ares_expand_name.c → src/lib/ares_expand_name.c} +114 -23
  1066. data/third_party/cares/cares/{ares_expand_string.c → src/lib/ares_expand_string.c} +2 -5
  1067. data/third_party/cares/cares/{ares_fds.c → src/lib/ares_fds.c} +0 -0
  1068. data/third_party/cares/cares/{ares_free_hostent.c → src/lib/ares_free_hostent.c} +6 -4
  1069. data/third_party/cares/cares/{ares_free_string.c → src/lib/ares_free_string.c} +0 -0
  1070. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +59 -0
  1071. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +772 -0
  1072. data/third_party/cares/cares/{ares_getenv.c → src/lib/ares_getenv.c} +0 -2
  1073. data/third_party/cares/cares/{ares_getenv.h → src/lib/ares_getenv.h} +0 -0
  1074. data/third_party/cares/cares/{ares_gethostbyaddr.c → src/lib/ares_gethostbyaddr.c} +2 -9
  1075. data/third_party/cares/cares/{ares_gethostbyname.c → src/lib/ares_gethostbyname.c} +25 -20
  1076. data/third_party/cares/cares/{ares_getnameinfo.c → src/lib/ares_getnameinfo.c} +4 -10
  1077. data/third_party/cares/cares/{ares_getsock.c → src/lib/ares_getsock.c} +0 -0
  1078. data/third_party/cares/cares/{ares_inet_net_pton.h → src/lib/ares_inet_net_pton.h} +0 -0
  1079. data/third_party/cares/cares/{ares_init.c → src/lib/ares_init.c} +79 -40
  1080. data/third_party/cares/cares/{ares_iphlpapi.h → src/lib/ares_iphlpapi.h} +0 -0
  1081. data/third_party/cares/cares/{ares_ipv6.h → src/lib/ares_ipv6.h} +7 -0
  1082. data/third_party/cares/cares/{ares_library_init.c → src/lib/ares_library_init.c} +7 -2
  1083. data/third_party/cares/cares/{ares_library_init.h → src/lib/ares_library_init.h} +1 -1
  1084. data/third_party/cares/cares/{ares_llist.c → src/lib/ares_llist.c} +0 -0
  1085. data/third_party/cares/cares/{ares_llist.h → src/lib/ares_llist.h} +0 -0
  1086. data/third_party/cares/cares/{ares_mkquery.c → src/lib/ares_mkquery.c} +0 -0
  1087. data/third_party/cares/cares/src/lib/ares_nameser.h +482 -0
  1088. data/third_party/cares/cares/{ares_nowarn.c → src/lib/ares_nowarn.c} +0 -0
  1089. data/third_party/cares/cares/{ares_nowarn.h → src/lib/ares_nowarn.h} +0 -0
  1090. data/third_party/cares/cares/{ares_options.c → src/lib/ares_options.c} +0 -0
  1091. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +209 -0
  1092. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +212 -0
  1093. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +199 -0
  1094. data/third_party/cares/cares/{ares_parse_mx_reply.c → src/lib/ares_parse_mx_reply.c} +2 -8
  1095. data/third_party/cares/cares/{ares_parse_naptr_reply.c → src/lib/ares_parse_naptr_reply.c} +2 -13
  1096. data/third_party/cares/cares/{ares_parse_ns_reply.c → src/lib/ares_parse_ns_reply.c} +5 -11
  1097. data/third_party/cares/cares/{ares_parse_ptr_reply.c → src/lib/ares_parse_ptr_reply.c} +53 -46
  1098. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +179 -0
  1099. data/third_party/cares/cares/{ares_parse_srv_reply.c → src/lib/ares_parse_srv_reply.c} +2 -13
  1100. data/third_party/cares/cares/{ares_parse_txt_reply.c → src/lib/ares_parse_txt_reply.c} +3 -9
  1101. data/third_party/cares/cares/{ares_platform.c → src/lib/ares_platform.c} +0 -0
  1102. data/third_party/cares/cares/{ares_platform.h → src/lib/ares_platform.h} +0 -0
  1103. data/third_party/cares/cares/{ares_private.h → src/lib/ares_private.h} +52 -11
  1104. data/third_party/cares/cares/{ares_process.c → src/lib/ares_process.c} +127 -52
  1105. data/third_party/cares/cares/{ares_query.c → src/lib/ares_query.c} +3 -9
  1106. data/third_party/cares/cares/{ares_search.c → src/lib/ares_search.c} +5 -7
  1107. data/third_party/cares/cares/{ares_send.c → src/lib/ares_send.c} +2 -8
  1108. data/third_party/cares/cares/{ares_setup.h → src/lib/ares_setup.h} +4 -1
  1109. data/third_party/cares/cares/{ares_strcasecmp.c → src/lib/ares_strcasecmp.c} +0 -0
  1110. data/third_party/cares/cares/{ares_strcasecmp.h → src/lib/ares_strcasecmp.h} +0 -0
  1111. data/third_party/cares/cares/{ares_strdup.c → src/lib/ares_strdup.c} +0 -0
  1112. data/third_party/cares/cares/{ares_strdup.h → src/lib/ares_strdup.h} +0 -0
  1113. data/third_party/cares/cares/{ares_strerror.c → src/lib/ares_strerror.c} +0 -0
  1114. data/third_party/cares/cares/{ares_strsplit.c → src/lib/ares_strsplit.c} +4 -0
  1115. data/third_party/cares/cares/{ares_strsplit.h → src/lib/ares_strsplit.h} +0 -0
  1116. data/third_party/cares/cares/{ares_timeout.c → src/lib/ares_timeout.c} +0 -0
  1117. data/third_party/cares/cares/{ares_version.c → src/lib/ares_version.c} +0 -0
  1118. data/third_party/cares/cares/{ares_writev.c → src/lib/ares_writev.c} +0 -0
  1119. data/third_party/cares/cares/src/lib/ares_writev.h +36 -0
  1120. data/third_party/cares/cares/{bitncmp.c → src/lib/bitncmp.c} +0 -0
  1121. data/third_party/cares/cares/{bitncmp.h → src/lib/bitncmp.h} +0 -0
  1122. data/third_party/cares/cares/src/lib/config-dos.h +115 -0
  1123. data/third_party/cares/cares/{config-win32.h → src/lib/config-win32.h} +0 -0
  1124. data/third_party/cares/cares/{inet_net_pton.c → src/lib/inet_net_pton.c} +2 -8
  1125. data/third_party/cares/cares/{inet_ntop.c → src/lib/inet_ntop.c} +2 -8
  1126. data/third_party/cares/cares/{setup_once.h → src/lib/setup_once.h} +0 -0
  1127. data/third_party/cares/cares/{windows_port.c → src/lib/windows_port.c} +0 -0
  1128. data/third_party/upb/third_party/utf8_range/naive.c +92 -0
  1129. data/third_party/upb/third_party/utf8_range/range2-neon.c +157 -0
  1130. data/third_party/upb/third_party/utf8_range/range2-sse.c +170 -0
  1131. data/third_party/upb/third_party/utf8_range/utf8_range.h +9 -0
  1132. data/third_party/upb/upb/decode.c +526 -319
  1133. data/third_party/upb/upb/decode.h +43 -17
  1134. data/third_party/upb/upb/decode_fast.c +303 -301
  1135. data/third_party/upb/upb/decode_fast.h +18 -18
  1136. data/third_party/upb/upb/decode_internal.h +73 -56
  1137. data/third_party/upb/upb/def.c +1863 -1078
  1138. data/third_party/upb/upb/def.h +318 -286
  1139. data/third_party/upb/upb/def.hpp +129 -172
  1140. data/third_party/upb/upb/encode.c +202 -175
  1141. data/third_party/upb/upb/encode.h +15 -17
  1142. data/third_party/upb/upb/msg.c +144 -124
  1143. data/third_party/upb/upb/msg.h +40 -33
  1144. data/third_party/upb/upb/msg_internal.h +321 -272
  1145. data/third_party/upb/upb/reflection.c +239 -199
  1146. data/third_party/upb/upb/reflection.h +87 -67
  1147. data/third_party/upb/upb/reflection.hpp +6 -6
  1148. data/third_party/upb/upb/table.c +222 -142
  1149. data/third_party/upb/upb/table_internal.h +128 -96
  1150. data/third_party/upb/upb/text_encode.c +113 -90
  1151. data/third_party/upb/upb/text_encode.h +10 -10
  1152. data/third_party/upb/upb/upb.c +111 -72
  1153. data/third_party/upb/upb/upb.h +120 -144
  1154. data/third_party/upb/upb/upb.hpp +31 -28
  1155. data/third_party/upb/upb/upb_internal.h +21 -11
  1156. data/third_party/xxhash/xxhash.h +607 -352
  1157. metadata +406 -203
  1158. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel.h +0 -44
  1159. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +0 -83
  1160. data/src/core/ext/filters/client_channel/resolver_registry.cc +0 -194
  1161. data/src/core/ext/filters/client_channel/resolver_registry.h +0 -88
  1162. data/src/core/ext/transport/chttp2/client/insecure/channel_create.cc +0 -122
  1163. data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.cc +0 -92
  1164. data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +0 -192
  1165. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +0 -52
  1166. data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +0 -79
  1167. data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +0 -125
  1168. data/src/core/ext/transport/chttp2/transport/chttp2_plugin.cc +0 -37
  1169. data/src/core/ext/transport/chttp2/transport/hpack_encoder_index.h +0 -107
  1170. data/src/core/ext/transport/chttp2/transport/hpack_utils.cc +0 -46
  1171. data/src/core/ext/transport/chttp2/transport/popularity_count.h +0 -60
  1172. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.c +0 -38
  1173. data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +0 -64
  1174. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.c +0 -38
  1175. data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +0 -64
  1176. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.c +0 -38
  1177. data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +0 -64
  1178. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.c +0 -38
  1179. data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +0 -64
  1180. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.c +0 -38
  1181. data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +0 -64
  1182. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/eval.upb.c +0 -102
  1183. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/eval.upb.h +0 -306
  1184. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/explain.upb.c +0 -56
  1185. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/explain.upb.h +0 -135
  1186. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/value.upb.c +0 -115
  1187. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/value.upb.h +0 -371
  1188. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.c +0 -67
  1189. data/src/core/ext/upbdefs-generated/envoy/service/cluster/v3/cds.upbdefs.h +0 -35
  1190. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.c +0 -68
  1191. data/src/core/ext/upbdefs-generated/envoy/service/endpoint/v3/eds.upbdefs.h +0 -35
  1192. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.c +0 -67
  1193. data/src/core/ext/upbdefs-generated/envoy/service/listener/v3/lds.upbdefs.h +0 -35
  1194. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.c +0 -75
  1195. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/rds.upbdefs.h +0 -35
  1196. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.c +0 -69
  1197. data/src/core/ext/upbdefs-generated/envoy/service/route/v3/srds.upbdefs.h +0 -35
  1198. data/src/core/lib/compression/algorithm_metadata.h +0 -62
  1199. data/src/core/lib/compression/compression_args.cc +0 -140
  1200. data/src/core/lib/compression/compression_args.h +0 -58
  1201. data/src/core/lib/compression/stream_compression.cc +0 -81
  1202. data/src/core/lib/compression/stream_compression.h +0 -117
  1203. data/src/core/lib/compression/stream_compression_gzip.cc +0 -231
  1204. data/src/core/lib/compression/stream_compression_gzip.h +0 -28
  1205. data/src/core/lib/compression/stream_compression_identity.cc +0 -91
  1206. data/src/core/lib/compression/stream_compression_identity.h +0 -29
  1207. data/src/core/lib/iomgr/iomgr_custom.cc +0 -79
  1208. data/src/core/lib/iomgr/iomgr_custom.h +0 -49
  1209. data/src/core/lib/iomgr/pollset_custom.cc +0 -105
  1210. data/src/core/lib/iomgr/pollset_custom.h +0 -37
  1211. data/src/core/lib/iomgr/pollset_set_custom.cc +0 -47
  1212. data/src/core/lib/iomgr/pollset_set_custom.h +0 -26
  1213. data/src/core/lib/iomgr/resolve_address_custom.cc +0 -169
  1214. data/src/core/lib/iomgr/resolve_address_custom.h +0 -44
  1215. data/src/core/lib/iomgr/tcp_client_custom.cc +0 -146
  1216. data/src/core/lib/iomgr/tcp_custom.cc +0 -350
  1217. data/src/core/lib/iomgr/tcp_custom.h +0 -85
  1218. data/src/core/lib/iomgr/tcp_server_custom.cc +0 -457
  1219. data/src/core/lib/iomgr/timer_custom.cc +0 -96
  1220. data/src/core/lib/iomgr/timer_custom.h +0 -43
  1221. data/src/core/lib/security/authorization/sdk_server_authz_filter.cc +0 -173
  1222. data/src/core/lib/security/authorization/sdk_server_authz_filter.h +0 -67
  1223. data/src/core/lib/security/credentials/credentials_metadata.cc +0 -61
  1224. data/src/core/lib/slice/slice_intern.cc +0 -367
  1225. data/src/core/lib/slice/slice_utils.h +0 -200
  1226. data/src/core/lib/slice/static_slice.cc +0 -377
  1227. data/src/core/lib/slice/static_slice.h +0 -300
  1228. data/src/core/lib/surface/init_secure.cc +0 -103
  1229. data/src/core/lib/transport/metadata.cc +0 -714
  1230. data/src/core/lib/transport/metadata.h +0 -449
  1231. data/src/core/lib/transport/metadata_batch.cc +0 -99
  1232. data/src/core/lib/transport/static_metadata.cc +0 -1032
  1233. data/src/core/lib/transport/static_metadata.h +0 -322
  1234. data/src/core/lib/transport/status_metadata.cc +0 -63
  1235. data/src/core/lib/transport/status_metadata.h +0 -48
  1236. data/third_party/cares/cares/ares_getopt.c +0 -122
  1237. data/third_party/cares/cares/ares_getopt.h +0 -53
  1238. data/third_party/cares/cares/ares_parse_a_reply.c +0 -264
  1239. data/third_party/cares/cares/ares_parse_aaaa_reply.c +0 -264
  1240. data/third_party/cares/cares/ares_parse_soa_reply.c +0 -133
@@ -27,6 +27,7 @@
27
27
  #include "absl/strings/str_format.h"
28
28
 
29
29
  #include <grpc/slice_buffer.h>
30
+ #include <grpc/status.h>
30
31
  #include <grpc/support/alloc.h>
31
32
  #include <grpc/support/log.h>
32
33
  #include <grpc/support/string_util.h>
@@ -36,7 +37,6 @@
36
37
  #include "src/core/ext/transport/chttp2/transport/internal.h"
37
38
  #include "src/core/ext/transport/chttp2/transport/varint.h"
38
39
  #include "src/core/lib/channel/channel_args.h"
39
- #include "src/core/lib/compression/stream_compression.h"
40
40
  #include "src/core/lib/debug/stats.h"
41
41
  #include "src/core/lib/gpr/env.h"
42
42
  #include "src/core/lib/gpr/string.h"
@@ -52,13 +52,18 @@
52
52
  #include "src/core/lib/slice/slice_string_helpers.h"
53
53
  #include "src/core/lib/transport/error_utils.h"
54
54
  #include "src/core/lib/transport/http2_errors.h"
55
- #include "src/core/lib/transport/static_metadata.h"
56
55
  #include "src/core/lib/transport/status_conversion.h"
57
56
  #include "src/core/lib/transport/timeout_encoding.h"
58
57
  #include "src/core/lib/transport/transport.h"
59
58
  #include "src/core/lib/transport/transport_impl.h"
60
59
  #include "src/core/lib/uri/uri_parser.h"
61
60
 
61
+ GPR_GLOBAL_CONFIG_DEFINE_BOOL(
62
+ grpc_experimental_disable_flow_control, false,
63
+ "If set, flow control will be effectively disabled. Max out all values and "
64
+ "assume the remote peer does the same. Thus we can ignore any flow control "
65
+ "bookkeeping, error checking, and decision making");
66
+
62
67
  #define DEFAULT_CONNECTION_WINDOW_TARGET (1024 * 1024)
63
68
  #define MAX_WINDOW 0x7fffffffu
64
69
  #define MAX_WRITE_BUFFER_SIZE (64 * 1024 * 1024)
@@ -164,16 +169,13 @@ static void keepalive_watchdog_fired_locked(void* arg, grpc_error_handle error);
164
169
 
165
170
  static void reset_byte_stream(void* arg, grpc_error_handle error);
166
171
 
167
- // Flow control default enabled. Can be disabled by setting
168
- // GRPC_EXPERIMENTAL_DISABLE_FLOW_CONTROL
169
- bool g_flow_control_enabled = true;
170
-
171
172
  namespace grpc_core {
172
173
 
173
174
  namespace {
174
175
  TestOnlyGlobalHttp2TransportInitCallback test_only_init_callback = nullptr;
175
176
  TestOnlyGlobalHttp2TransportDestructCallback test_only_destruct_callback =
176
177
  nullptr;
178
+ bool test_only_disable_transient_failure_state_notification = false;
177
179
  } // namespace
178
180
 
179
181
  void TestOnlySetGlobalHttp2TransportInitCallback(
@@ -186,6 +188,11 @@ void TestOnlySetGlobalHttp2TransportDestructCallback(
186
188
  test_only_destruct_callback = callback;
187
189
  }
188
190
 
191
+ void TestOnlyGlobalHttp2TransportDisableTransientFailureStateNotification(
192
+ bool disable) {
193
+ test_only_disable_transient_failure_state_notification = disable;
194
+ }
195
+
189
196
  } // namespace grpc_core
190
197
 
191
198
  //
@@ -294,11 +301,11 @@ static bool read_channel_args(grpc_chttp2_transport* t,
294
301
  strcmp(channel_args->args[i].key,
295
302
  GRPC_ARG_HTTP2_MIN_RECV_PING_INTERVAL_WITHOUT_DATA_MS)) {
296
303
  t->ping_policy.min_recv_ping_interval_without_data =
297
- grpc_channel_arg_get_integer(
304
+ grpc_core::Duration::Milliseconds(grpc_channel_arg_get_integer(
298
305
  &channel_args->args[i],
299
306
  grpc_integer_options{
300
307
  g_default_min_recv_ping_interval_without_data_ms, 0,
301
- INT_MAX});
308
+ INT_MAX}));
302
309
  } else if (0 == strcmp(channel_args->args[i].key,
303
310
  GRPC_ARG_HTTP2_WRITE_BUFFER_SIZE)) {
304
311
  t->write_buffer_size = static_cast<uint32_t>(grpc_channel_arg_get_integer(
@@ -314,7 +321,9 @@ static bool read_channel_args(grpc_chttp2_transport* t,
314
321
  ? g_default_client_keepalive_time_ms
315
322
  : g_default_server_keepalive_time_ms,
316
323
  1, INT_MAX});
317
- t->keepalive_time = value == INT_MAX ? GRPC_MILLIS_INF_FUTURE : value;
324
+ t->keepalive_time = value == INT_MAX
325
+ ? grpc_core::Duration::Infinity()
326
+ : grpc_core::Duration::Milliseconds(value);
318
327
  } else if (0 == strcmp(channel_args->args[i].key,
319
328
  GRPC_ARG_KEEPALIVE_TIMEOUT_MS)) {
320
329
  const int value = grpc_channel_arg_get_integer(
@@ -323,7 +332,9 @@ static bool read_channel_args(grpc_chttp2_transport* t,
323
332
  ? g_default_client_keepalive_timeout_ms
324
333
  : g_default_server_keepalive_timeout_ms,
325
334
  0, INT_MAX});
326
- t->keepalive_timeout = value == INT_MAX ? GRPC_MILLIS_INF_FUTURE : value;
335
+ t->keepalive_timeout = value == INT_MAX
336
+ ? grpc_core::Duration::Infinity()
337
+ : grpc_core::Duration::Milliseconds(value);
327
338
  } else if (0 == strcmp(channel_args->args[i].key,
328
339
  GRPC_ARG_KEEPALIVE_PERMIT_WITHOUT_CALLS)) {
329
340
  t->keepalive_permit_without_calls = static_cast<uint32_t>(
@@ -399,20 +410,24 @@ static bool read_channel_args(grpc_chttp2_transport* t,
399
410
  static void init_transport_keepalive_settings(grpc_chttp2_transport* t) {
400
411
  if (t->is_client) {
401
412
  t->keepalive_time = g_default_client_keepalive_time_ms == INT_MAX
402
- ? GRPC_MILLIS_INF_FUTURE
403
- : g_default_client_keepalive_time_ms;
413
+ ? grpc_core::Duration::Infinity()
414
+ : grpc_core::Duration::Milliseconds(
415
+ g_default_client_keepalive_time_ms);
404
416
  t->keepalive_timeout = g_default_client_keepalive_timeout_ms == INT_MAX
405
- ? GRPC_MILLIS_INF_FUTURE
406
- : g_default_client_keepalive_timeout_ms;
417
+ ? grpc_core::Duration::Infinity()
418
+ : grpc_core::Duration::Milliseconds(
419
+ g_default_client_keepalive_timeout_ms);
407
420
  t->keepalive_permit_without_calls =
408
421
  g_default_client_keepalive_permit_without_calls;
409
422
  } else {
410
423
  t->keepalive_time = g_default_server_keepalive_time_ms == INT_MAX
411
- ? GRPC_MILLIS_INF_FUTURE
412
- : g_default_server_keepalive_time_ms;
424
+ ? grpc_core::Duration::Infinity()
425
+ : grpc_core::Duration::Milliseconds(
426
+ g_default_server_keepalive_time_ms);
413
427
  t->keepalive_timeout = g_default_server_keepalive_timeout_ms == INT_MAX
414
- ? GRPC_MILLIS_INF_FUTURE
415
- : g_default_server_keepalive_timeout_ms;
428
+ ? grpc_core::Duration::Infinity()
429
+ : grpc_core::Duration::Milliseconds(
430
+ g_default_server_keepalive_timeout_ms);
416
431
  t->keepalive_permit_without_calls =
417
432
  g_default_server_keepalive_permit_without_calls;
418
433
  }
@@ -422,11 +437,12 @@ static void configure_transport_ping_policy(grpc_chttp2_transport* t) {
422
437
  t->ping_policy.max_pings_without_data = g_default_max_pings_without_data;
423
438
  t->ping_policy.max_ping_strikes = g_default_max_ping_strikes;
424
439
  t->ping_policy.min_recv_ping_interval_without_data =
425
- g_default_min_recv_ping_interval_without_data_ms;
440
+ grpc_core::Duration::Milliseconds(
441
+ g_default_min_recv_ping_interval_without_data_ms);
426
442
  }
427
443
 
428
444
  static void init_keepalive_pings_if_enabled(grpc_chttp2_transport* t) {
429
- if (t->keepalive_time != GRPC_MILLIS_INF_FUTURE) {
445
+ if (t->keepalive_time != grpc_core::Duration::Infinity()) {
430
446
  t->keepalive_state = GRPC_CHTTP2_KEEPALIVE_STATE_WAITING;
431
447
  GRPC_CHTTP2_REF_TRANSPORT(t, "init keepalive ping");
432
448
  GRPC_CLOSURE_INIT(&t->init_keepalive_ping_locked, init_keepalive_ping, t,
@@ -505,7 +521,9 @@ grpc_chttp2_transport::grpc_chttp2_transport(
505
521
  enable_bdp = read_channel_args(this, channel_args, is_client);
506
522
  }
507
523
 
508
- if (g_flow_control_enabled) {
524
+ static const bool kEnableFlowControl =
525
+ !GPR_GLOBAL_CONFIG_GET(grpc_experimental_disable_flow_control);
526
+ if (kEnableFlowControl) {
509
527
  flow_control.Init<grpc_core::chttp2::TransportFlowControl>(this,
510
528
  enable_bdp);
511
529
  } else {
@@ -516,9 +534,9 @@ grpc_chttp2_transport::grpc_chttp2_transport(
516
534
  // No pings allowed before receiving a header or data frame.
517
535
  ping_state.pings_before_data_required = 0;
518
536
  ping_state.is_delayed_ping_timer_set = false;
519
- ping_state.last_ping_sent_time = GRPC_MILLIS_INF_PAST;
537
+ ping_state.last_ping_sent_time = grpc_core::Timestamp::InfPast();
520
538
 
521
- ping_recv_state.last_ping_recv_time = GRPC_MILLIS_INF_PAST;
539
+ ping_recv_state.last_ping_recv_time = grpc_core::Timestamp::InfPast();
522
540
  ping_recv_state.ping_strikes = 0;
523
541
 
524
542
  init_keepalive_pings_if_enabled(this);
@@ -649,10 +667,6 @@ grpc_chttp2_stream::grpc_chttp2_stream(grpc_chttp2_transport* t,
649
667
  : t(t),
650
668
  refcount(refcount),
651
669
  reffer(this),
652
- stream_reservation(t->memory_owner.MakeReservation(
653
- grpc_core::kResourceQuotaCallSize)), // TODO(ctiller): sizeof(*this),
654
- // or better, move allocation to
655
- // memory quota.
656
670
  initial_metadata_buffer(arena),
657
671
  trailing_metadata_buffer(arena) {
658
672
  if (server_data) {
@@ -692,13 +706,6 @@ grpc_chttp2_stream::~grpc_chttp2_stream() {
692
706
 
693
707
  grpc_slice_buffer_destroy_internal(&unprocessed_incoming_frames_buffer);
694
708
  grpc_slice_buffer_destroy_internal(&frame_storage);
695
- if (stream_compression_method != GRPC_STREAM_COMPRESSION_IDENTITY_COMPRESS) {
696
- grpc_slice_buffer_destroy_internal(&compressed_data_buffer);
697
- }
698
- if (stream_decompression_method !=
699
- GRPC_STREAM_COMPRESSION_IDENTITY_DECOMPRESS) {
700
- grpc_slice_buffer_destroy_internal(&decompressed_data_buffer);
701
- }
702
709
 
703
710
  for (int i = 0; i < STREAM_LIST_COUNT; i++) {
704
711
  if (GPR_UNLIKELY(included[i])) {
@@ -743,18 +750,6 @@ static void destroy_stream(grpc_transport* gt, grpc_stream* gs,
743
750
  GPR_TIMER_SCOPE("destroy_stream", 0);
744
751
  grpc_chttp2_transport* t = reinterpret_cast<grpc_chttp2_transport*>(gt);
745
752
  grpc_chttp2_stream* s = reinterpret_cast<grpc_chttp2_stream*>(gs);
746
- if (s->stream_compression_method !=
747
- GRPC_STREAM_COMPRESSION_IDENTITY_COMPRESS &&
748
- s->stream_compression_ctx != nullptr) {
749
- grpc_stream_compression_context_destroy(s->stream_compression_ctx);
750
- s->stream_compression_ctx = nullptr;
751
- }
752
- if (s->stream_decompression_method !=
753
- GRPC_STREAM_COMPRESSION_IDENTITY_DECOMPRESS &&
754
- s->stream_decompression_ctx != nullptr) {
755
- grpc_stream_compression_context_destroy(s->stream_decompression_ctx);
756
- s->stream_decompression_ctx = nullptr;
757
- }
758
753
 
759
754
  s->destroy_stream_arg = then_schedule_closure;
760
755
  t->combiner->Run(
@@ -1067,6 +1062,19 @@ static void queue_setting_update(grpc_chttp2_transport* t,
1067
1062
  }
1068
1063
  }
1069
1064
 
1065
+ // Cancel out streams that haven't yet started if we have received a GOAWAY
1066
+ static void cancel_unstarted_streams(grpc_chttp2_transport* t,
1067
+ grpc_error_handle error) {
1068
+ grpc_chttp2_stream* s;
1069
+ while (grpc_chttp2_list_pop_waiting_for_concurrency(t, &s)) {
1070
+ s->trailing_metadata_buffer.Set(
1071
+ grpc_core::GrpcStreamNetworkState(),
1072
+ grpc_core::GrpcStreamNetworkState::kNotSentOnWire);
1073
+ grpc_chttp2_cancel_stream(t, s, GRPC_ERROR_REF(error));
1074
+ }
1075
+ GRPC_ERROR_UNREF(error);
1076
+ }
1077
+
1070
1078
  void grpc_chttp2_add_incoming_goaway(grpc_chttp2_transport* t,
1071
1079
  uint32_t goaway_error,
1072
1080
  uint32_t last_stream_id,
@@ -1092,6 +1100,22 @@ void grpc_chttp2_add_incoming_goaway(grpc_chttp2_transport* t,
1092
1100
  gpr_log(GPR_INFO, "%s: Got goaway [%d] err=%s", t->peer_string.c_str(),
1093
1101
  goaway_error, grpc_error_std_string(t->goaway_error).c_str());
1094
1102
  }
1103
+ cancel_unstarted_streams(t, GRPC_ERROR_REF(t->goaway_error));
1104
+ // Cancel all unseen streams
1105
+ grpc_chttp2_stream_map_for_each(
1106
+ &t->stream_map,
1107
+ [](void* user_data, uint32_t /* key */, void* stream) {
1108
+ uint32_t last_stream_id = *(static_cast<uint32_t*>(user_data));
1109
+ grpc_chttp2_stream* s = static_cast<grpc_chttp2_stream*>(stream);
1110
+ if (s->id > last_stream_id) {
1111
+ s->trailing_metadata_buffer.Set(
1112
+ grpc_core::GrpcStreamNetworkState(),
1113
+ grpc_core::GrpcStreamNetworkState::kNotSeenByServer);
1114
+ grpc_chttp2_cancel_stream(s->t, s,
1115
+ GRPC_ERROR_REF(s->t->goaway_error));
1116
+ }
1117
+ },
1118
+ &last_stream_id);
1095
1119
  absl::Status status = grpc_error_to_absl_status(t->goaway_error);
1096
1120
  // When a client receives a GOAWAY with error code ENHANCE_YOUR_CALM and debug
1097
1121
  // data equal to "too_many_pings", it should log the occurrence at a log level
@@ -1103,34 +1127,29 @@ void grpc_chttp2_add_incoming_goaway(grpc_chttp2_transport* t,
1103
1127
  gpr_log(GPR_ERROR,
1104
1128
  "Received a GOAWAY with error code ENHANCE_YOUR_CALM and debug "
1105
1129
  "data equal to \"too_many_pings\"");
1106
- double current_keepalive_time_ms = static_cast<double>(t->keepalive_time);
1107
- constexpr int max_keepalive_time_ms =
1108
- INT_MAX / KEEPALIVE_TIME_BACKOFF_MULTIPLIER;
1130
+ constexpr auto max_keepalive_time = grpc_core::Duration::Milliseconds(
1131
+ INT_MAX / KEEPALIVE_TIME_BACKOFF_MULTIPLIER);
1109
1132
  t->keepalive_time =
1110
- current_keepalive_time_ms > static_cast<double>(max_keepalive_time_ms)
1111
- ? GRPC_MILLIS_INF_FUTURE
1112
- : static_cast<grpc_millis>(current_keepalive_time_ms *
1113
- KEEPALIVE_TIME_BACKOFF_MULTIPLIER);
1133
+ t->keepalive_time > max_keepalive_time
1134
+ ? grpc_core::Duration::Infinity()
1135
+ : t->keepalive_time * KEEPALIVE_TIME_BACKOFF_MULTIPLIER;
1114
1136
  status.SetPayload(grpc_core::kKeepaliveThrottlingKey,
1115
- absl::Cord(std::to_string(t->keepalive_time)));
1137
+ absl::Cord(std::to_string(t->keepalive_time.millis())));
1116
1138
  }
1117
1139
  // lie: use transient failure from the transport to indicate goaway has been
1118
1140
  // received.
1119
- connectivity_state_set(t, GRPC_CHANNEL_TRANSIENT_FAILURE, status,
1120
- "got_goaway");
1141
+ if (!grpc_core::test_only_disable_transient_failure_state_notification) {
1142
+ connectivity_state_set(t, GRPC_CHANNEL_TRANSIENT_FAILURE, status,
1143
+ "got_goaway");
1144
+ }
1121
1145
  }
1122
1146
 
1123
1147
  static void maybe_start_some_streams(grpc_chttp2_transport* t) {
1124
1148
  grpc_chttp2_stream* s;
1125
- // cancel out streams that haven't yet started if we have received a GOAWAY
1149
+ // maybe cancel out streams that haven't yet started if we have received a
1150
+ // GOAWAY
1126
1151
  if (t->goaway_error != GRPC_ERROR_NONE) {
1127
- while (grpc_chttp2_list_pop_waiting_for_concurrency(t, &s)) {
1128
- grpc_chttp2_cancel_stream(
1129
- t, s,
1130
- grpc_error_set_int(
1131
- GRPC_ERROR_CREATE_FROM_STATIC_STRING("GOAWAY received"),
1132
- GRPC_ERROR_INT_GRPC_STATUS, GRPC_STATUS_UNAVAILABLE));
1133
- }
1152
+ cancel_unstarted_streams(t, GRPC_ERROR_REF(t->goaway_error));
1134
1153
  return;
1135
1154
  }
1136
1155
  // start streams where we have free grpc_chttp2_stream ids and free
@@ -1165,6 +1184,9 @@ static void maybe_start_some_streams(grpc_chttp2_transport* t) {
1165
1184
  // cancel out streams that will never be started
1166
1185
  if (t->next_stream_id >= MAX_CLIENT_STREAM_ID) {
1167
1186
  while (grpc_chttp2_list_pop_waiting_for_concurrency(t, &s)) {
1187
+ s->trailing_metadata_buffer.Set(
1188
+ grpc_core::GrpcStreamNetworkState(),
1189
+ grpc_core::GrpcStreamNetworkState::kNotSentOnWire);
1168
1190
  grpc_chttp2_cancel_stream(
1169
1191
  t, s,
1170
1192
  grpc_error_set_int(
@@ -1219,37 +1241,49 @@ void grpc_chttp2_complete_closure_step(grpc_chttp2_transport* t,
1219
1241
  write_state_name(t->write_state));
1220
1242
  }
1221
1243
  if (error != GRPC_ERROR_NONE) {
1222
- if (closure->error_data.error == GRPC_ERROR_NONE) {
1223
- closure->error_data.error = GRPC_ERROR_CREATE_FROM_STATIC_STRING(
1244
+ #ifdef GRPC_ERROR_IS_ABSEIL_STATUS
1245
+ grpc_error_handle cl_err =
1246
+ grpc_core::internal::StatusMoveFromHeapPtr(closure->error_data.error);
1247
+ #else
1248
+ grpc_error_handle cl_err =
1249
+ reinterpret_cast<grpc_error_handle>(closure->error_data.error);
1250
+ #endif
1251
+ if (cl_err == GRPC_ERROR_NONE) {
1252
+ cl_err = GRPC_ERROR_CREATE_FROM_STATIC_STRING(
1224
1253
  "Error in HTTP transport completing operation");
1225
- closure->error_data.error =
1226
- grpc_error_set_str(closure->error_data.error,
1227
- GRPC_ERROR_STR_TARGET_ADDRESS, t->peer_string);
1254
+ cl_err = grpc_error_set_str(cl_err, GRPC_ERROR_STR_TARGET_ADDRESS,
1255
+ t->peer_string);
1228
1256
  }
1229
- closure->error_data.error =
1230
- grpc_error_add_child(closure->error_data.error, error);
1257
+ cl_err = grpc_error_add_child(cl_err, error);
1258
+ #ifdef GRPC_ERROR_IS_ABSEIL_STATUS
1259
+ closure->error_data.error = grpc_core::internal::StatusAllocHeapPtr(cl_err);
1260
+ #else
1261
+ closure->error_data.error = reinterpret_cast<intptr_t>(cl_err);
1262
+ #endif
1231
1263
  }
1232
1264
  if (closure->next_data.scratch < CLOSURE_BARRIER_FIRST_REF_BIT) {
1233
1265
  if ((t->write_state == GRPC_CHTTP2_WRITE_STATE_IDLE) ||
1234
1266
  !(closure->next_data.scratch & CLOSURE_BARRIER_MAY_COVER_WRITE)) {
1235
1267
  // Using GRPC_CLOSURE_SCHED instead of GRPC_CLOSURE_RUN to avoid running
1236
1268
  // closures earlier than when it is safe to do so.
1237
- grpc_core::ExecCtx::Run(DEBUG_LOCATION, closure,
1238
- closure->error_data.error);
1269
+ #ifdef GRPC_ERROR_IS_ABSEIL_STATUS
1270
+ grpc_error_handle run_error =
1271
+ grpc_core::internal::StatusMoveFromHeapPtr(closure->error_data.error);
1272
+ #else
1273
+ grpc_error_handle run_error =
1274
+ reinterpret_cast<grpc_error_handle>(closure->error_data.error);
1275
+ #endif
1276
+ closure->error_data.error = 0;
1277
+ grpc_core::ExecCtx::Run(DEBUG_LOCATION, closure, run_error);
1239
1278
  } else {
1240
- grpc_closure_list_append(&t->run_after_write, closure,
1241
- closure->error_data.error);
1279
+ grpc_closure_list_append(&t->run_after_write, closure);
1242
1280
  }
1243
1281
  }
1244
1282
  }
1245
1283
 
1246
1284
  static bool contains_non_ok_status(grpc_metadata_batch* batch) {
1247
- if (batch->legacy_index()->named.grpc_status != nullptr) {
1248
- return !grpc_mdelem_static_value_eq(
1249
- batch->legacy_index()->named.grpc_status->md,
1250
- GRPC_MDELEM_GRPC_STATUS_0);
1251
- }
1252
- return false;
1285
+ return batch->get(grpc_core::GrpcStatusMetadata()).value_or(GRPC_STATUS_OK) !=
1286
+ GRPC_STATUS_OK;
1253
1287
  }
1254
1288
 
1255
1289
  static void maybe_become_writable_due_to_send_msg(grpc_chttp2_transport* t,
@@ -1342,13 +1376,10 @@ static void complete_fetch_locked(void* gs, grpc_error_handle error) {
1342
1376
 
1343
1377
  static void log_metadata(const grpc_metadata_batch* md_batch, uint32_t id,
1344
1378
  bool is_client, bool is_initial) {
1345
- md_batch->ForEach([=](grpc_mdelem md) {
1346
- char* key = grpc_slice_to_c_string(GRPC_MDKEY(md));
1347
- char* value = grpc_slice_to_c_string(GRPC_MDVALUE(md));
1348
- gpr_log(GPR_INFO, "HTTP:%d:%s:%s: %s: %s", id, is_initial ? "HDR" : "TRL",
1349
- is_client ? "CLI" : "SVR", key, value);
1350
- gpr_free(key);
1351
- gpr_free(value);
1379
+ const std::string prefix = absl::StrCat(
1380
+ "HTTP:", id, is_initial ? ":HDR" : ":TRL", is_client ? ":CLI:" : ":SVR:");
1381
+ md_batch->Log([&prefix](absl::string_view key, absl::string_view value) {
1382
+ gpr_log(GPR_INFO, "%s", absl::StrCat(prefix, key, ": ", value).c_str());
1352
1383
  });
1353
1384
  }
1354
1385
 
@@ -1368,8 +1399,10 @@ static void perform_stream_op_locked(void* stream_op,
1368
1399
  s->context = op->payload->context;
1369
1400
  s->traced = op->is_traced;
1370
1401
  if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
1371
- gpr_log(GPR_INFO, "perform_stream_op_locked: %s; on_complete = %p",
1372
- grpc_transport_stream_op_batch_string(op).c_str(), op->on_complete);
1402
+ gpr_log(GPR_INFO,
1403
+ "perform_stream_op_locked[s=%p; op=%p]: %s; on_complete = %p", s,
1404
+ op, grpc_transport_stream_op_batch_string(op).c_str(),
1405
+ op->on_complete);
1373
1406
  if (op->send_initial_metadata) {
1374
1407
  log_metadata(op_payload->send_initial_metadata.send_initial_metadata,
1375
1408
  s->id, t->is_client, true);
@@ -1386,7 +1419,7 @@ static void perform_stream_op_locked(void* stream_op,
1386
1419
  // This batch has send ops. Use final_data as a barrier until enqueue time;
1387
1420
  // the initial counter is dropped at the end of this function.
1388
1421
  on_complete->next_data.scratch = CLOSURE_BARRIER_FIRST_REF_BIT;
1389
- on_complete->error_data.error = GRPC_ERROR_NONE;
1422
+ on_complete->error_data.error = 0;
1390
1423
  }
1391
1424
 
1392
1425
  if (op->cancel_stream) {
@@ -1402,23 +1435,6 @@ static void perform_stream_op_locked(void* stream_op,
1402
1435
  GPR_ASSERT(s->send_initial_metadata_finished == nullptr);
1403
1436
  on_complete->next_data.scratch |= CLOSURE_BARRIER_MAY_COVER_WRITE;
1404
1437
 
1405
- // Identify stream compression
1406
- if (op_payload->send_initial_metadata.send_initial_metadata->legacy_index()
1407
- ->named.content_encoding == nullptr ||
1408
- grpc_stream_compression_method_parse(
1409
- GRPC_MDVALUE(
1410
- op_payload->send_initial_metadata.send_initial_metadata
1411
- ->legacy_index()
1412
- ->named.content_encoding->md),
1413
- true, &s->stream_compression_method) == 0) {
1414
- s->stream_compression_method = GRPC_STREAM_COMPRESSION_IDENTITY_COMPRESS;
1415
- }
1416
- if (s->stream_compression_method !=
1417
- GRPC_STREAM_COMPRESSION_IDENTITY_COMPRESS) {
1418
- s->uncompressed_data_size = 0;
1419
- s->stream_compression_ctx = nullptr;
1420
- grpc_slice_buffer_init(&s->compressed_data_buffer);
1421
- }
1422
1438
  s->send_initial_metadata_finished = add_closure_barrier(on_complete);
1423
1439
  s->send_initial_metadata =
1424
1440
  op_payload->send_initial_metadata.send_initial_metadata;
@@ -1426,7 +1442,7 @@ static void perform_stream_op_locked(void* stream_op,
1426
1442
  s->deadline = std::min(
1427
1443
  s->deadline,
1428
1444
  s->send_initial_metadata->get(grpc_core::GrpcTimeoutMetadata())
1429
- .value_or(GRPC_MILLIS_INF_FUTURE));
1445
+ .value_or(grpc_core::Timestamp::InfFuture()));
1430
1446
  }
1431
1447
  if (contains_non_ok_status(s->send_initial_metadata)) {
1432
1448
  s->seen_error = true;
@@ -1438,6 +1454,9 @@ static void perform_stream_op_locked(void* stream_op,
1438
1454
  grpc_chttp2_list_add_waiting_for_concurrency(t, s);
1439
1455
  maybe_start_some_streams(t);
1440
1456
  } else {
1457
+ s->trailing_metadata_buffer.Set(
1458
+ grpc_core::GrpcStreamNetworkState(),
1459
+ grpc_core::GrpcStreamNetworkState::kNotSentOnWire);
1441
1460
  grpc_chttp2_cancel_stream(
1442
1461
  t, s,
1443
1462
  grpc_error_set_int(
@@ -1630,7 +1649,7 @@ static void perform_stream_op(grpc_transport* gt, grpc_stream* gs,
1630
1649
  }
1631
1650
 
1632
1651
  if (GRPC_TRACE_FLAG_ENABLED(grpc_http_trace)) {
1633
- gpr_log(GPR_INFO, "perform_stream_op[s=%p]: %s", s,
1652
+ gpr_log(GPR_INFO, "perform_stream_op[s=%p; op=%p]: %s", s, op,
1634
1653
  grpc_transport_stream_op_batch_string(op).c_str());
1635
1654
  }
1636
1655
 
@@ -1745,8 +1764,8 @@ static void send_goaway(grpc_chttp2_transport* t, grpc_error_handle error) {
1745
1764
  t->sent_goaway_state = GRPC_CHTTP2_GOAWAY_SEND_SCHEDULED;
1746
1765
  grpc_http2_error_code http_error;
1747
1766
  std::string message;
1748
- grpc_error_get_status(error, GRPC_MILLIS_INF_FUTURE, nullptr, &message,
1749
- &http_error, nullptr);
1767
+ grpc_error_get_status(error, grpc_core::Timestamp::InfFuture(), nullptr,
1768
+ &message, &http_error, nullptr);
1750
1769
  grpc_chttp2_goaway_append(
1751
1770
  t->last_new_stream_id, static_cast<uint32_t>(http_error),
1752
1771
  grpc_slice_from_cpp_string(std::move(message)), &t->qbuf);
@@ -1771,7 +1790,7 @@ void grpc_chttp2_add_ping_strike(grpc_chttp2_transport* t) {
1771
1790
 
1772
1791
  void grpc_chttp2_reset_ping_clock(grpc_chttp2_transport* t) {
1773
1792
  if (!t->is_client) {
1774
- t->ping_recv_state.last_ping_recv_time = GRPC_MILLIS_INF_PAST;
1793
+ t->ping_recv_state.last_ping_recv_time = grpc_core::Timestamp::InfPast();
1775
1794
  t->ping_recv_state.ping_strikes = 0;
1776
1795
  }
1777
1796
  t->ping_state.pings_before_data_required =
@@ -1852,6 +1871,15 @@ void grpc_chttp2_maybe_complete_recv_initial_metadata(
1852
1871
  }
1853
1872
  }
1854
1873
  *s->recv_initial_metadata = std::move(s->initial_metadata_buffer);
1874
+ // If we didn't receive initial metadata from the wire and instead faked a
1875
+ // status (due to stream cancellations for example), let upper layers know
1876
+ // that trailing metadata is immediately available.
1877
+ if (s->trailing_metadata_available != nullptr &&
1878
+ s->published_metadata[0] != GRPC_METADATA_PUBLISHED_FROM_WIRE &&
1879
+ s->published_metadata[1] == GRPC_METADATA_SYNTHESIZED_FROM_FAKE) {
1880
+ *s->trailing_metadata_available = true;
1881
+ s->trailing_metadata_available = nullptr;
1882
+ }
1855
1883
  null_then_sched_closure(&s->recv_initial_metadata_ready);
1856
1884
  }
1857
1885
  }
@@ -1874,48 +1902,10 @@ void grpc_chttp2_maybe_complete_recv_message(grpc_chttp2_transport* /*t*/,
1874
1902
  if (s->unprocessed_incoming_frames_buffer.length == 0) {
1875
1903
  grpc_slice_buffer_swap(&s->unprocessed_incoming_frames_buffer,
1876
1904
  &s->frame_storage);
1877
- s->unprocessed_incoming_frames_decompressed = false;
1878
- }
1879
- if (!s->unprocessed_incoming_frames_decompressed &&
1880
- s->stream_decompression_method !=
1881
- GRPC_STREAM_COMPRESSION_IDENTITY_DECOMPRESS) {
1882
- GPR_ASSERT(s->decompressed_data_buffer.length == 0);
1883
- bool end_of_context;
1884
- if (!s->stream_decompression_ctx) {
1885
- s->stream_decompression_ctx =
1886
- grpc_stream_compression_context_create(
1887
- s->stream_decompression_method);
1888
- }
1889
- if (!grpc_stream_decompress(
1890
- s->stream_decompression_ctx,
1891
- &s->unprocessed_incoming_frames_buffer,
1892
- &s->decompressed_data_buffer, nullptr,
1893
- GRPC_HEADER_SIZE_IN_BYTES - s->decompressed_header_bytes,
1894
- &end_of_context)) {
1895
- grpc_slice_buffer_reset_and_unref_internal(&s->frame_storage);
1896
- grpc_slice_buffer_reset_and_unref_internal(
1897
- &s->unprocessed_incoming_frames_buffer);
1898
- error = GRPC_ERROR_CREATE_FROM_STATIC_STRING(
1899
- "Stream decompression error.");
1900
- } else {
1901
- s->decompressed_header_bytes += s->decompressed_data_buffer.length;
1902
- if (s->decompressed_header_bytes == GRPC_HEADER_SIZE_IN_BYTES) {
1903
- s->decompressed_header_bytes = 0;
1904
- }
1905
- error = grpc_deframe_unprocessed_incoming_frames(
1906
- &s->data_parser, s, &s->decompressed_data_buffer, nullptr,
1907
- s->recv_message);
1908
- if (end_of_context) {
1909
- grpc_stream_compression_context_destroy(
1910
- s->stream_decompression_ctx);
1911
- s->stream_decompression_ctx = nullptr;
1912
- }
1913
- }
1914
- } else {
1915
- error = grpc_deframe_unprocessed_incoming_frames(
1916
- &s->data_parser, s, &s->unprocessed_incoming_frames_buffer,
1917
- nullptr, s->recv_message);
1918
1905
  }
1906
+ error = grpc_deframe_unprocessed_incoming_frames(
1907
+ &s->data_parser, s, &s->unprocessed_incoming_frames_buffer, nullptr,
1908
+ s->recv_message);
1919
1909
  if (error != GRPC_ERROR_NONE) {
1920
1910
  s->seen_error = true;
1921
1911
  grpc_slice_buffer_reset_and_unref_internal(&s->frame_storage);
@@ -1963,42 +1953,12 @@ void grpc_chttp2_maybe_complete_recv_trailing_metadata(grpc_chttp2_transport* t,
1963
1953
  !s->seen_error && s->recv_trailing_metadata_finished != nullptr) {
1964
1954
  // Maybe some SYNC_FLUSH data is left in frame_storage. Consume them and
1965
1955
  // maybe decompress the next 5 bytes in the stream.
1966
- if (s->stream_decompression_method ==
1967
- GRPC_STREAM_COMPRESSION_IDENTITY_DECOMPRESS) {
1968
- grpc_slice_buffer_move_first(
1969
- &s->frame_storage,
1970
- std::min(s->frame_storage.length,
1971
- size_t(GRPC_HEADER_SIZE_IN_BYTES)),
1972
- &s->unprocessed_incoming_frames_buffer);
1973
- if (s->unprocessed_incoming_frames_buffer.length > 0) {
1974
- s->unprocessed_incoming_frames_decompressed = true;
1975
- pending_data = true;
1976
- }
1977
- } else {
1978
- bool end_of_context;
1979
- if (!s->stream_decompression_ctx) {
1980
- s->stream_decompression_ctx = grpc_stream_compression_context_create(
1981
- s->stream_decompression_method);
1982
- }
1983
- if (!grpc_stream_decompress(
1984
- s->stream_decompression_ctx, &s->frame_storage,
1985
- &s->unprocessed_incoming_frames_buffer, nullptr,
1986
- GRPC_HEADER_SIZE_IN_BYTES, &end_of_context)) {
1987
- grpc_slice_buffer_reset_and_unref_internal(&s->frame_storage);
1988
- grpc_slice_buffer_reset_and_unref_internal(
1989
- &s->unprocessed_incoming_frames_buffer);
1990
- s->seen_error = true;
1991
- } else {
1992
- if (s->unprocessed_incoming_frames_buffer.length > 0) {
1993
- s->unprocessed_incoming_frames_decompressed = true;
1994
- pending_data = true;
1995
- }
1996
- if (end_of_context) {
1997
- grpc_stream_compression_context_destroy(
1998
- s->stream_decompression_ctx);
1999
- s->stream_decompression_ctx = nullptr;
2000
- }
2001
- }
1956
+ grpc_slice_buffer_move_first(
1957
+ &s->frame_storage,
1958
+ std::min(s->frame_storage.length, size_t(GRPC_HEADER_SIZE_IN_BYTES)),
1959
+ &s->unprocessed_incoming_frames_buffer);
1960
+ if (s->unprocessed_incoming_frames_buffer.length > 0) {
1961
+ pending_data = true;
2002
1962
  }
2003
1963
  }
2004
1964
  if (s->read_closed && s->frame_storage.length == 0 && !pending_data &&
@@ -2095,12 +2055,7 @@ void grpc_chttp2_fake_status(grpc_chttp2_transport* t, grpc_chttp2_stream* s,
2095
2055
  // about the metadata yet
2096
2056
  if (s->published_metadata[1] == GRPC_METADATA_NOT_PUBLISHED ||
2097
2057
  s->recv_trailing_metadata_finished != nullptr) {
2098
- char status_string[GPR_LTOA_MIN_BUFSIZE];
2099
- gpr_ltoa(status, status_string);
2100
- GRPC_LOG_IF_ERROR("add_status",
2101
- s->trailing_metadata_buffer.ReplaceOrAppend(
2102
- GRPC_MDSTR_GRPC_STATUS,
2103
- grpc_core::UnmanagedMemorySlice(status_string)));
2058
+ s->trailing_metadata_buffer.Set(grpc_core::GrpcStatusMetadata(), status);
2104
2059
  if (!message.empty()) {
2105
2060
  s->trailing_metadata_buffer.Set(
2106
2061
  grpc_core::GrpcMessageMetadata(),
@@ -2413,6 +2368,7 @@ static void end_all_the_calls(grpc_chttp2_transport* t,
2413
2368
  error = grpc_error_set_int(error, GRPC_ERROR_INT_GRPC_STATUS,
2414
2369
  GRPC_STATUS_UNAVAILABLE);
2415
2370
  }
2371
+ cancel_unstarted_streams(t, GRPC_ERROR_REF(error));
2416
2372
  cancel_stream_cb_args args = {error, t};
2417
2373
  grpc_chttp2_stream_map_for_each(&t->stream_map, cancel_stream_cb, &args);
2418
2374
  GRPC_ERROR_UNREF(error);
@@ -2656,7 +2612,8 @@ static void finish_bdp_ping_locked(void* tp, grpc_error_handle error) {
2656
2612
  return;
2657
2613
  }
2658
2614
  t->bdp_ping_started = false;
2659
- grpc_millis next_ping = t->flow_control->bdp_estimator()->CompletePing();
2615
+ grpc_core::Timestamp next_ping =
2616
+ t->flow_control->bdp_estimator()->CompletePing();
2660
2617
  grpc_chttp2_act_on_flowctl_action(t->flow_control->PeriodicUpdate(), t,
2661
2618
  nullptr);
2662
2619
  GPR_ASSERT(!t->have_next_bdp_ping_timer);
@@ -2989,7 +2946,6 @@ void Chttp2IncomingByteStream::NextLocked(void* arg,
2989
2946
  if (s->frame_storage.length > 0) {
2990
2947
  grpc_slice_buffer_swap(&s->frame_storage,
2991
2948
  &s->unprocessed_incoming_frames_buffer);
2992
- s->unprocessed_incoming_frames_decompressed = false;
2993
2949
  ExecCtx::Run(DEBUG_LOCATION, bs->next_action_.on_complete, GRPC_ERROR_NONE);
2994
2950
  } else if (s->byte_stream_error != GRPC_ERROR_NONE) {
2995
2951
  ExecCtx::Run(DEBUG_LOCATION, bs->next_action_.on_complete,
@@ -3035,45 +2991,10 @@ bool Chttp2IncomingByteStream::Next(size_t max_size_hint,
3035
2991
  }
3036
2992
  }
3037
2993
 
3038
- void Chttp2IncomingByteStream::MaybeCreateStreamDecompressionCtx() {
3039
- GPR_DEBUG_ASSERT(stream_->stream_decompression_method !=
3040
- GRPC_STREAM_COMPRESSION_IDENTITY_DECOMPRESS);
3041
- if (!stream_->stream_decompression_ctx) {
3042
- stream_->stream_decompression_ctx = grpc_stream_compression_context_create(
3043
- stream_->stream_decompression_method);
3044
- }
3045
- }
3046
-
3047
2994
  grpc_error_handle Chttp2IncomingByteStream::Pull(grpc_slice* slice) {
3048
2995
  GPR_TIMER_SCOPE("incoming_byte_stream_pull", 0);
3049
2996
  grpc_error_handle error;
3050
2997
  if (stream_->unprocessed_incoming_frames_buffer.length > 0) {
3051
- if (!stream_->unprocessed_incoming_frames_decompressed &&
3052
- stream_->stream_decompression_method !=
3053
- GRPC_STREAM_COMPRESSION_IDENTITY_DECOMPRESS) {
3054
- bool end_of_context;
3055
- MaybeCreateStreamDecompressionCtx();
3056
- if (!grpc_stream_decompress(stream_->stream_decompression_ctx,
3057
- &stream_->unprocessed_incoming_frames_buffer,
3058
- &stream_->decompressed_data_buffer, nullptr,
3059
- MAX_SIZE_T, &end_of_context)) {
3060
- error =
3061
- GRPC_ERROR_CREATE_FROM_STATIC_STRING("Stream decompression error.");
3062
- return error;
3063
- }
3064
- GPR_ASSERT(stream_->unprocessed_incoming_frames_buffer.length == 0);
3065
- grpc_slice_buffer_swap(&stream_->unprocessed_incoming_frames_buffer,
3066
- &stream_->decompressed_data_buffer);
3067
- stream_->unprocessed_incoming_frames_decompressed = true;
3068
- if (end_of_context) {
3069
- grpc_stream_compression_context_destroy(
3070
- stream_->stream_decompression_ctx);
3071
- stream_->stream_decompression_ctx = nullptr;
3072
- }
3073
- if (stream_->unprocessed_incoming_frames_buffer.length == 0) {
3074
- *slice = grpc_empty_slice();
3075
- }
3076
- }
3077
2998
  error = grpc_deframe_unprocessed_incoming_frames(
3078
2999
  &stream_->data_parser, stream_,
3079
3000
  &stream_->unprocessed_incoming_frames_buffer, slice, nullptr);
@@ -3300,6 +3221,7 @@ static grpc_endpoint* chttp2_get_endpoint(grpc_transport* t) {
3300
3221
  static const grpc_transport_vtable vtable = {sizeof(grpc_chttp2_stream),
3301
3222
  "chttp2",
3302
3223
  init_stream,
3224
+ nullptr,
3303
3225
  set_pollset,
3304
3226
  set_pollset_set,
3305
3227
  perform_stream_op,