grpc 1.54.2 → 1.55.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (971) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +68 -37
  3. data/include/grpc/impl/grpc_types.h +2 -0
  4. data/src/core/ext/filters/backend_metrics/backend_metric_filter.cc +1 -1
  5. data/src/core/ext/filters/client_channel/backend_metric.cc +2 -1
  6. data/src/core/ext/filters/client_channel/client_channel.cc +17 -23
  7. data/src/core/ext/filters/client_channel/client_channel.h +22 -16
  8. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +1 -1
  9. data/src/core/ext/filters/client_channel/client_channel_internal.h +8 -40
  10. data/src/core/ext/filters/client_channel/client_channel_service_config.cc +2 -2
  11. data/src/core/ext/filters/client_channel/config_selector.h +5 -17
  12. data/src/core/ext/filters/client_channel/health/health_check_client.cc +1 -1
  13. data/src/core/ext/filters/client_channel/http_proxy.cc +34 -1
  14. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +2 -2
  15. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +1 -1
  16. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +1 -1
  17. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +5 -5
  18. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +3 -3
  19. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +44 -45
  20. data/src/core/ext/filters/client_channel/lb_policy/weighted_round_robin/weighted_round_robin.cc +2 -3
  21. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +3 -3
  22. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +3 -3
  23. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +4 -4
  24. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +3 -3
  25. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +9 -9
  26. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_override_host.cc +4 -4
  27. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_wrr_locality.cc +5 -4
  28. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +19 -118
  29. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.h +30 -0
  30. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_plugin.cc +60 -0
  31. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_plugin.h +27 -0
  32. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.cc +524 -0
  33. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/event_engine_client_channel_resolver.h +35 -0
  34. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.cc +97 -0
  35. data/src/core/ext/filters/client_channel/resolver/dns/event_engine/service_config_helper.h +32 -0
  36. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +2 -13
  37. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.h +24 -0
  38. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +3 -2
  39. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +7 -34
  40. data/src/core/ext/filters/client_channel/retry_filter.cc +23 -55
  41. data/src/core/ext/filters/client_channel/retry_service_config.cc +8 -8
  42. data/src/core/ext/filters/fault_injection/fault_injection_service_config_parser.cc +1 -1
  43. data/src/core/ext/filters/http/message_compress/compression_filter.cc +2 -2
  44. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +68 -69
  45. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +78 -23
  46. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +21 -0
  47. data/src/core/ext/transport/chttp2/transport/context_list_entry.h +70 -0
  48. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +1 -7
  49. data/src/core/ext/transport/chttp2/transport/frame_ping.h +0 -3
  50. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +1 -0
  51. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.cc +176 -0
  52. data/src/core/ext/transport/chttp2/transport/hpack_parse_result.h +325 -0
  53. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +567 -543
  54. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +150 -9
  55. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +47 -32
  56. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +18 -5
  57. data/src/core/ext/transport/chttp2/transport/internal.h +3 -4
  58. data/src/core/ext/transport/chttp2/transport/parsing.cc +12 -12
  59. data/src/core/ext/transport/chttp2/transport/writing.cc +14 -3
  60. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +87 -52
  61. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +414 -181
  62. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +121 -60
  63. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +481 -224
  64. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +90 -55
  65. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +415 -188
  66. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +357 -210
  67. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +1572 -729
  68. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +30 -17
  69. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +144 -47
  70. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +34 -21
  71. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +160 -62
  72. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +27 -14
  73. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +78 -38
  74. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +20 -11
  75. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +48 -26
  76. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +20 -11
  77. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +48 -26
  78. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +109 -62
  79. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +566 -244
  80. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +21 -12
  81. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +45 -30
  82. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +22 -19
  83. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +82 -29
  84. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +23 -16
  85. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +45 -30
  86. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +230 -143
  87. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +733 -404
  88. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +417 -264
  89. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +1839 -899
  90. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -41
  91. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +286 -148
  92. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +531 -334
  93. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +2017 -1131
  94. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +21 -12
  95. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +45 -30
  96. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +89 -52
  97. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +347 -232
  98. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +264 -165
  99. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +888 -476
  100. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +139 -80
  101. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +527 -274
  102. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +22 -13
  103. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +50 -36
  104. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +380 -221
  105. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +1168 -611
  106. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +166 -94
  107. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +666 -292
  108. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +18 -11
  109. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +37 -26
  110. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +21 -12
  111. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +45 -30
  112. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +30 -17
  113. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +144 -47
  114. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +274 -167
  115. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +789 -440
  116. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +228 -137
  117. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +1100 -501
  118. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +22 -13
  119. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +60 -37
  120. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +350 -211
  121. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +1072 -646
  122. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +33 -18
  123. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +117 -51
  124. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +34 -19
  125. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +118 -56
  126. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +38 -21
  127. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +148 -64
  128. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +31 -18
  129. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +143 -65
  130. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +22 -13
  131. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +51 -37
  132. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +78 -43
  133. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +265 -127
  134. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +145 -88
  135. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +438 -241
  136. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +115 -62
  137. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +559 -227
  138. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +18 -11
  139. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +35 -26
  140. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +175 -118
  141. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +857 -442
  142. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +172 -95
  143. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +864 -374
  144. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +48 -27
  145. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +159 -110
  146. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +39 -18
  147. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +74 -56
  148. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +28 -15
  149. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +71 -45
  150. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +131 -74
  151. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +489 -249
  152. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +135 -80
  153. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +505 -245
  154. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +248 -139
  155. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +933 -433
  156. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +80 -49
  157. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +616 -201
  158. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +1283 -776
  159. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +5422 -2519
  160. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +49 -28
  161. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +164 -84
  162. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +228 -141
  163. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +738 -399
  164. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +20 -11
  165. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +48 -26
  166. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +21 -12
  167. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +45 -30
  168. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +32 -19
  169. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +70 -49
  170. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +27 -14
  171. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +110 -43
  172. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +46 -25
  173. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +259 -100
  174. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +21 -12
  175. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +45 -30
  176. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +18 -11
  177. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +35 -26
  178. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +42 -23
  179. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +108 -70
  180. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +7 -4
  181. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +21 -16
  182. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +43 -24
  183. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +110 -75
  184. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +30 -17
  185. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +95 -50
  186. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +16 -9
  187. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +73 -23
  188. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +60 -37
  189. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +150 -108
  190. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +74 -43
  191. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +357 -167
  192. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +44 -25
  193. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +114 -80
  194. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +41 -20
  195. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +245 -82
  196. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.c +32 -19
  197. data/src/core/ext/upb-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +73 -51
  198. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +474 -296
  199. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +2121 -1076
  200. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.c +18 -11
  201. data/src/core/ext/upb-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upb.h +35 -26
  202. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.c +34 -21
  203. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/client_side_weighted_round_robin/v3/client_side_weighted_round_robin.upb.h +112 -78
  204. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.c +72 -45
  205. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +193 -138
  206. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +34 -21
  207. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +119 -78
  208. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +18 -11
  209. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +35 -26
  210. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +7 -4
  211. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +15 -10
  212. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +184 -96
  213. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +907 -360
  214. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +56 -33
  215. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +150 -101
  216. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +188 -111
  217. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +816 -419
  218. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +32 -19
  219. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +109 -53
  220. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +10 -7
  221. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +18 -14
  222. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +300 -177
  223. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +1284 -522
  224. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +42 -23
  225. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +188 -75
  226. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +130 -83
  227. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +510 -238
  228. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +22 -13
  229. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +55 -34
  230. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +39 -26
  231. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +124 -68
  232. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.c +21 -12
  233. data/src/core/ext/upb-generated/envoy/type/matcher/v3/filter_state.upb.h +47 -30
  234. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +52 -29
  235. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +92 -62
  236. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +37 -20
  237. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +133 -63
  238. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +22 -13
  239. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +91 -40
  240. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +21 -12
  241. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +50 -32
  242. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +18 -11
  243. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +37 -26
  244. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +46 -27
  245. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +101 -70
  246. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.c +13 -10
  247. data/src/core/ext/upb-generated/envoy/type/matcher/v3/status_code_input.upb.h +25 -22
  248. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +40 -23
  249. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +161 -75
  250. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +31 -18
  251. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +114 -56
  252. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +46 -29
  253. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +139 -91
  254. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +65 -42
  255. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +200 -121
  256. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +80 -45
  257. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +208 -131
  258. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +34 -21
  259. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +74 -53
  260. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +7 -4
  261. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +13 -8
  262. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +16 -9
  263. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +28 -18
  264. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +28 -15
  265. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +55 -34
  266. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +43 -22
  267. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +91 -53
  268. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +35 -20
  269. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +92 -57
  270. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +7 -4
  271. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +13 -8
  272. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +20 -11
  273. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +48 -26
  274. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +23 -14
  275. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +61 -41
  276. data/src/core/ext/upb-generated/google/api/annotations.upb.c +14 -11
  277. data/src/core/ext/upb-generated/google/api/annotations.upb.h +30 -20
  278. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +255 -154
  279. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +934 -450
  280. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +299 -180
  281. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +946 -483
  282. data/src/core/ext/upb-generated/google/api/http.upb.c +68 -35
  283. data/src/core/ext/upb-generated/google/api/http.upb.h +284 -120
  284. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +22 -13
  285. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +95 -37
  286. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +19 -10
  287. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +38 -22
  288. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +1018 -424
  289. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +3851 -1412
  290. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +19 -10
  291. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +38 -22
  292. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +10 -7
  293. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +18 -14
  294. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +62 -39
  295. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +207 -102
  296. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +19 -10
  297. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +38 -22
  298. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +90 -51
  299. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +157 -107
  300. data/src/core/ext/upb-generated/google/rpc/status.upb.c +22 -13
  301. data/src/core/ext/upb-generated/google/rpc/status.upb.h +95 -37
  302. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +59 -34
  303. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +154 -92
  304. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +43 -24
  305. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +118 -60
  306. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +250 -145
  307. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +919 -415
  308. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +34 -19
  309. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +76 -51
  310. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +25 -14
  311. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +45 -30
  312. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +144 -81
  313. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +405 -217
  314. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +51 -26
  315. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +153 -61
  316. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +173 -102
  317. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +855 -298
  318. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +68 -49
  319. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +155 -104
  320. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +26 -17
  321. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +55 -34
  322. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +12 -9
  323. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +31 -14
  324. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +26 -17
  325. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +55 -34
  326. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +23 -16
  327. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +45 -30
  328. data/src/core/ext/upb-generated/validate/validate.upb.c +845 -455
  329. data/src/core/ext/upb-generated/validate/validate.upb.h +4347 -1908
  330. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +68 -49
  331. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +155 -104
  332. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +26 -17
  333. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +55 -34
  334. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +12 -9
  335. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +31 -14
  336. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +65 -44
  337. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +137 -91
  338. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +23 -16
  339. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +45 -30
  340. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +16 -9
  341. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +28 -18
  342. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.c +21 -12
  343. data/src/core/ext/upb-generated/xds/core/v3/cidr.upb.h +45 -30
  344. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +37 -22
  345. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +96 -63
  346. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +26 -17
  347. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +52 -29
  348. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +21 -12
  349. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +45 -30
  350. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +23 -14
  351. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +62 -42
  352. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +44 -25
  353. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +169 -79
  354. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +27 -14
  355. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +65 -38
  356. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +69 -38
  357. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +167 -76
  358. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +21 -12
  359. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +89 -34
  360. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.c +18 -11
  361. data/src/core/ext/upb-generated/xds/type/matcher/v3/cel.upb.h +35 -26
  362. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.c +32 -19
  363. data/src/core/ext/upb-generated/xds/type/matcher/v3/domain.upb.h +150 -54
  364. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.c +10 -7
  365. data/src/core/ext/upb-generated/xds/type/matcher/v3/http_inputs.upb.h +18 -14
  366. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.c +34 -21
  367. data/src/core/ext/upb-generated/xds/type/matcher/v3/ip.upb.h +161 -63
  368. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +162 -101
  369. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +501 -293
  370. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.c +85 -52
  371. data/src/core/ext/upb-generated/xds/type/matcher/v3/range.upb.h +430 -164
  372. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +24 -15
  373. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +53 -37
  374. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +40 -23
  375. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +161 -75
  376. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.c +37 -22
  377. data/src/core/ext/upb-generated/xds/type/v3/cel.upb.h +92 -66
  378. data/src/core/ext/upb-generated/xds/type/v3/range.upb.c +43 -22
  379. data/src/core/ext/upb-generated/xds/type/v3/range.upb.h +91 -53
  380. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +21 -12
  381. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +45 -30
  382. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +1 -1
  383. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +6 -5
  384. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +1 -1
  385. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +6 -5
  386. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +1 -1
  387. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +6 -5
  388. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +1 -1
  389. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +6 -5
  390. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +1 -1
  391. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +6 -5
  392. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +1 -1
  393. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +6 -5
  394. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +1 -1
  395. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +6 -5
  396. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +1 -1
  397. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +6 -5
  398. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +1 -1
  399. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +6 -5
  400. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +1 -1
  401. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +6 -5
  402. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +1 -1
  403. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +6 -5
  404. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +1 -1
  405. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +6 -5
  406. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +1 -1
  407. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +6 -5
  408. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +1 -1
  409. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +6 -5
  410. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +252 -253
  411. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +6 -5
  412. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +1 -1
  413. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +6 -5
  414. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +1 -1
  415. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +6 -5
  416. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +1 -1
  417. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +6 -5
  418. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +1 -1
  419. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +6 -5
  420. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +1 -1
  421. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +6 -5
  422. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +1 -1
  423. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +6 -5
  424. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +1 -1
  425. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +6 -5
  426. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +1 -1
  427. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +6 -5
  428. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +13 -12
  429. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +11 -5
  430. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +1 -1
  431. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +6 -5
  432. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +1 -1
  433. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +6 -5
  434. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +1 -1
  435. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +6 -5
  436. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +1 -1
  437. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +6 -5
  438. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +1 -1
  439. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +6 -5
  440. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +1 -1
  441. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +6 -5
  442. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +44 -44
  443. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +6 -5
  444. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +1 -1
  445. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +6 -5
  446. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +1 -1
  447. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +6 -5
  448. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +1 -1
  449. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +6 -5
  450. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +1 -1
  451. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +6 -5
  452. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +1 -1
  453. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +6 -5
  454. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +1 -1
  455. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +6 -5
  456. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +1 -1
  457. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +6 -5
  458. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +1 -1
  459. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +6 -5
  460. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +1 -1
  461. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +6 -5
  462. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +1 -1
  463. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +6 -5
  464. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +1 -1
  465. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +6 -5
  466. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +1 -1
  467. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +6 -5
  468. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +1 -1
  469. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +6 -5
  470. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +1 -1
  471. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +6 -5
  472. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +1 -1
  473. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +6 -5
  474. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +1 -1
  475. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +6 -5
  476. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +134 -128
  477. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +11 -5
  478. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +1 -1
  479. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +6 -5
  480. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +1 -1
  481. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +6 -5
  482. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +1 -1
  483. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +6 -5
  484. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +1 -1
  485. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +6 -5
  486. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +1 -1
  487. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +6 -5
  488. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +1 -1
  489. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +6 -5
  490. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +1 -1
  491. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +6 -5
  492. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +1 -1
  493. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +6 -5
  494. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +1 -1
  495. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +6 -5
  496. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +1 -1
  497. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +6 -5
  498. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +1 -1
  499. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +6 -5
  500. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +1 -1
  501. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +6 -5
  502. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +1 -1
  503. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +6 -5
  504. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +1 -1
  505. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +6 -5
  506. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +1 -1
  507. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +6 -5
  508. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +1 -1
  509. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +6 -5
  510. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +1 -1
  511. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +6 -5
  512. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +1 -1
  513. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +6 -5
  514. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +1 -1
  515. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +6 -5
  516. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +1 -1
  517. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +6 -5
  518. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +1 -1
  519. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +6 -5
  520. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +379 -376
  521. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +6 -5
  522. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +1 -1
  523. data/src/core/ext/upbdefs-generated/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +6 -5
  524. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +1 -1
  525. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +6 -5
  526. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +138 -136
  527. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +6 -5
  528. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +1 -1
  529. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +6 -5
  530. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +1 -1
  531. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +6 -5
  532. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +1 -1
  533. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +6 -5
  534. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +1 -1
  535. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +6 -5
  536. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +1 -1
  537. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +6 -5
  538. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +1 -1
  539. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +6 -5
  540. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +12 -13
  541. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +6 -5
  542. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +1 -1
  543. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +6 -5
  544. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +1 -1
  545. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +6 -5
  546. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.c +1 -1
  547. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/filter_state.upbdefs.h +6 -5
  548. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +1 -1
  549. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +6 -5
  550. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +1 -1
  551. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +6 -5
  552. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +1 -1
  553. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +6 -5
  554. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +1 -1
  555. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +6 -5
  556. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +1 -1
  557. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +6 -5
  558. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +1 -1
  559. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +6 -5
  560. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.c +1 -1
  561. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/status_code_input.upbdefs.h +6 -5
  562. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +1 -1
  563. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +6 -5
  564. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +1 -1
  565. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +6 -5
  566. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +1 -1
  567. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +6 -5
  568. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +1 -1
  569. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +6 -5
  570. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +1 -1
  571. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +6 -5
  572. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +1 -1
  573. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +6 -5
  574. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +1 -1
  575. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +6 -5
  576. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +1 -1
  577. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +6 -5
  578. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +1 -1
  579. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +6 -5
  580. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +1 -1
  581. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +6 -5
  582. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +1 -1
  583. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +6 -5
  584. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +1 -1
  585. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +6 -5
  586. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +1 -1
  587. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +6 -5
  588. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +1 -1
  589. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +6 -5
  590. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +1 -1
  591. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +6 -5
  592. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +1 -1
  593. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +6 -5
  594. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +1 -1
  595. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +6 -5
  596. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +1 -1
  597. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +6 -5
  598. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +1 -1
  599. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +6 -5
  600. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +1 -1
  601. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +6 -5
  602. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +329 -273
  603. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +11 -5
  604. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +1 -1
  605. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +6 -5
  606. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +1 -1
  607. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +6 -5
  608. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +1 -1
  609. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +6 -5
  610. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +1 -1
  611. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +6 -5
  612. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +1 -1
  613. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +6 -5
  614. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +1 -1
  615. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +6 -5
  616. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +1 -1
  617. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +6 -5
  618. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +1 -1
  619. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +6 -5
  620. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +1 -1
  621. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +6 -5
  622. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +1 -1
  623. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +6 -5
  624. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +1 -1
  625. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +6 -5
  626. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +1 -1
  627. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +6 -5
  628. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +1 -1
  629. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +6 -5
  630. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +1 -1
  631. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +6 -5
  632. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +1 -1
  633. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +6 -5
  634. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +1 -1
  635. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +6 -5
  636. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +1 -1
  637. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +6 -5
  638. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +1 -1
  639. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +6 -5
  640. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +1 -1
  641. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +6 -5
  642. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +1 -1
  643. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +6 -5
  644. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.c +1 -1
  645. data/src/core/ext/upbdefs-generated/xds/core/v3/cidr.upbdefs.h +6 -5
  646. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +1 -1
  647. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +6 -5
  648. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +1 -1
  649. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +6 -5
  650. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +1 -1
  651. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +6 -5
  652. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +1 -1
  653. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +6 -5
  654. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +1 -1
  655. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +6 -5
  656. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +1 -1
  657. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +6 -5
  658. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.c +1 -1
  659. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/cel.upbdefs.h +6 -5
  660. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.c +1 -1
  661. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/domain.upbdefs.h +6 -5
  662. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.c +1 -1
  663. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/http_inputs.upbdefs.h +6 -5
  664. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.c +1 -1
  665. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/ip.upbdefs.h +6 -5
  666. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +1 -1
  667. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +6 -5
  668. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.c +1 -1
  669. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/range.upbdefs.h +6 -5
  670. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +1 -1
  671. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +6 -5
  672. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +1 -1
  673. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +6 -5
  674. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.c +1 -1
  675. data/src/core/ext/upbdefs-generated/xds/type/v3/cel.upbdefs.h +6 -5
  676. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.c +1 -1
  677. data/src/core/ext/upbdefs-generated/xds/type/v3/range.upbdefs.h +6 -5
  678. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +1 -1
  679. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +6 -5
  680. data/src/core/ext/xds/certificate_provider_store.cc +4 -4
  681. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +7 -7
  682. data/src/core/ext/xds/upb_utils.h +1 -1
  683. data/src/core/ext/xds/xds_api.cc +34 -14
  684. data/src/core/ext/xds/xds_api.h +2 -2
  685. data/src/core/ext/xds/xds_bootstrap.cc +3 -3
  686. data/src/core/ext/xds/xds_bootstrap_grpc.cc +15 -15
  687. data/src/core/ext/xds/xds_client.cc +24 -3
  688. data/src/core/ext/xds/xds_client.h +1 -1
  689. data/src/core/ext/xds/xds_cluster.cc +26 -34
  690. data/src/core/ext/xds/xds_cluster.h +1 -2
  691. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +4 -3
  692. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +2 -2
  693. data/src/core/ext/xds/xds_common_types.cc +5 -4
  694. data/src/core/ext/xds/xds_endpoint.cc +5 -2
  695. data/src/core/ext/xds/xds_endpoint.h +1 -1
  696. data/src/core/ext/xds/xds_http_fault_filter.cc +2 -2
  697. data/src/core/ext/xds/xds_http_fault_filter.h +1 -1
  698. data/src/core/ext/xds/xds_http_filters.h +3 -2
  699. data/src/core/ext/xds/xds_http_rbac_filter.cc +6 -8
  700. data/src/core/ext/xds/xds_http_rbac_filter.h +1 -1
  701. data/src/core/ext/xds/xds_http_stateful_session_filter.cc +2 -2
  702. data/src/core/ext/xds/xds_http_stateful_session_filter.h +1 -1
  703. data/src/core/ext/xds/xds_lb_policy_registry.cc +4 -22
  704. data/src/core/ext/xds/xds_listener.cc +10 -4
  705. data/src/core/ext/xds/xds_listener.h +1 -1
  706. data/src/core/ext/xds/xds_resource_type.h +2 -2
  707. data/src/core/ext/xds/xds_route_config.cc +8 -5
  708. data/src/core/ext/xds/xds_route_config.h +1 -1
  709. data/src/core/lib/backoff/random_early_detection.h +5 -0
  710. data/src/core/lib/channel/channelz.cc +5 -4
  711. data/src/core/lib/channel/channelz_registry.cc +7 -6
  712. data/src/core/lib/channel/connected_channel.cc +82 -27
  713. data/src/core/lib/channel/promise_based_filter.cc +2 -8
  714. data/src/core/lib/debug/trace.cc +16 -7
  715. data/src/core/lib/debug/trace.h +12 -4
  716. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +38 -43
  717. data/src/core/lib/event_engine/posix_engine/posix_engine.h +1 -0
  718. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.cc +29 -0
  719. data/src/core/lib/event_engine/posix_engine/posix_engine_listener.h +3 -0
  720. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.cc +6 -1
  721. data/src/core/lib/event_engine/posix_engine/tcp_socket_utils.h +3 -0
  722. data/src/core/lib/event_engine/shim.cc +2 -0
  723. data/src/core/lib/event_engine/trace.cc +1 -0
  724. data/src/core/lib/event_engine/trace.h +6 -0
  725. data/src/core/lib/experiments/experiments.cc +3 -0
  726. data/src/core/lib/experiments/experiments.h +4 -1
  727. data/src/core/lib/gpr/posix/time.cc +5 -0
  728. data/src/core/lib/gprpp/status_helper.cc +2 -2
  729. data/src/core/lib/gprpp/validation_errors.cc +8 -3
  730. data/src/core/lib/gprpp/validation_errors.h +16 -9
  731. data/src/core/lib/iomgr/buffer_list.h +0 -1
  732. data/src/core/lib/iomgr/socket_utils_posix.cc +3 -0
  733. data/src/core/lib/iomgr/socket_utils_posix.h +3 -0
  734. data/src/core/lib/iomgr/tcp_client_posix.cc +4 -0
  735. data/src/core/lib/iomgr/tcp_server_posix.cc +39 -14
  736. data/src/core/lib/iomgr/tcp_server_utils_posix.h +12 -0
  737. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +21 -0
  738. data/src/core/lib/iomgr/timer_generic.cc +17 -16
  739. data/src/core/lib/json/json.h +61 -113
  740. data/src/core/lib/json/json_object_loader.cc +20 -20
  741. data/src/core/lib/json/json_object_loader.h +8 -3
  742. data/src/core/lib/json/json_reader.cc +58 -38
  743. data/src/core/lib/json/json_reader.h +34 -0
  744. data/src/core/lib/json/json_util.cc +6 -6
  745. data/src/core/lib/json/json_util.h +5 -4
  746. data/src/core/lib/json/json_writer.cc +19 -19
  747. data/src/core/lib/json/json_writer.h +33 -0
  748. data/src/core/lib/load_balancing/lb_policy_registry.cc +7 -7
  749. data/src/core/lib/promise/pipe.h +7 -0
  750. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +35 -37
  751. data/src/core/lib/security/credentials/external/external_account_credentials.cc +60 -62
  752. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +22 -21
  753. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +28 -27
  754. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +4 -2
  755. data/src/core/lib/security/credentials/jwt/json_token.cc +6 -4
  756. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +8 -5
  757. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +39 -38
  758. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +17 -16
  759. data/src/core/lib/security/util/json_util.cc +5 -5
  760. data/src/core/lib/service_config/service_config_impl.cc +11 -5
  761. data/src/core/lib/slice/slice.h +2 -0
  762. data/src/core/lib/surface/call.cc +71 -26
  763. data/src/core/lib/surface/call.h +1 -5
  764. data/src/core/lib/surface/completion_queue.cc +2 -1
  765. data/src/core/lib/surface/server.cc +47 -19
  766. data/src/core/lib/surface/validate_metadata.cc +37 -22
  767. data/src/core/lib/surface/validate_metadata.h +13 -3
  768. data/src/core/lib/surface/version.cc +2 -2
  769. data/src/core/lib/transport/batch_builder.h +9 -1
  770. data/src/core/lib/transport/metadata_batch.h +2 -59
  771. data/src/core/lib/transport/metadata_compression_traits.h +67 -0
  772. data/src/core/lib/transport/simple_slice_based_metadata.h +48 -0
  773. data/src/core/lib/transport/transport.h +3 -0
  774. data/src/core/plugin_registry/grpc_plugin_registry.cc +2 -4
  775. data/src/ruby/lib/grpc/version.rb +1 -1
  776. data/third_party/abseil-cpp/absl/base/config.h +1 -1
  777. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +33 -47
  778. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +7 -4
  779. data/third_party/boringssl-with-bazel/src/crypto/kyber/internal.h +32 -2
  780. data/third_party/boringssl-with-bazel/src/crypto/kyber/keccak.c +11 -12
  781. data/third_party/boringssl-with-bazel/src/crypto/kyber/kyber.c +826 -0
  782. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +10 -12
  783. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +8 -10
  784. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +2 -1
  785. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +2 -1
  786. data/third_party/boringssl-with-bazel/src/crypto/x509/policy.c +18 -14
  787. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +17 -21
  788. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +7 -3
  789. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +3 -4
  790. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +1 -72
  791. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +4 -2
  792. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +4 -3
  793. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +7 -3
  794. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +4 -2
  795. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +1 -1
  796. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +8 -8
  797. data/third_party/boringssl-with-bazel/src/include/openssl/kyber.h +128 -0
  798. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +8 -1
  799. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +1 -1
  800. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +8 -12
  801. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +1 -10
  802. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +9 -2
  803. data/third_party/boringssl-with-bazel/src/ssl/internal.h +17 -17
  804. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +8 -4
  805. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +2 -2
  806. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +72 -5
  807. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +19 -21
  808. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +2 -1
  809. data/third_party/upb/upb/{table_internal.h → alloc.h} +6 -6
  810. data/third_party/upb/upb/arena.h +4 -193
  811. data/third_party/upb/upb/array.h +4 -51
  812. data/third_party/upb/upb/base/descriptor_constants.h +104 -0
  813. data/third_party/upb/upb/base/log2.h +57 -0
  814. data/third_party/upb/upb/{status.c → base/status.c} +2 -7
  815. data/third_party/upb/upb/base/status.h +66 -0
  816. data/third_party/upb/upb/base/string_view.h +75 -0
  817. data/third_party/upb/upb/{array.c → collections/array.c} +67 -36
  818. data/third_party/upb/upb/collections/array.h +85 -0
  819. data/third_party/upb/upb/collections/array_internal.h +135 -0
  820. data/third_party/upb/upb/{map.c → collections/map.c} +53 -26
  821. data/third_party/upb/upb/collections/map.h +135 -0
  822. data/third_party/upb/upb/collections/map_gencode_util.h +78 -0
  823. data/third_party/upb/upb/collections/map_internal.h +170 -0
  824. data/third_party/upb/upb/collections/map_sorter.c +166 -0
  825. data/third_party/upb/upb/collections/map_sorter_internal.h +109 -0
  826. data/third_party/upb/upb/{message_value.h → collections/message_value.h} +12 -13
  827. data/third_party/upb/upb/decode.h +3 -62
  828. data/third_party/upb/upb/def.h +4 -384
  829. data/third_party/upb/upb/def.hpp +3 -411
  830. data/third_party/upb/upb/encode.h +3 -48
  831. data/third_party/upb/upb/extension_registry.h +3 -52
  832. data/third_party/upb/upb/{table.c → hash/common.c} +52 -110
  833. data/third_party/upb/upb/hash/common.h +199 -0
  834. data/third_party/upb/upb/hash/int_table.h +102 -0
  835. data/third_party/upb/upb/hash/str_table.h +161 -0
  836. data/third_party/upb/upb/{json_decode.c → json/decode.c} +63 -98
  837. data/third_party/upb/upb/json/decode.h +52 -0
  838. data/third_party/upb/upb/{json_encode.c → json/encode.c} +69 -45
  839. data/third_party/upb/upb/json/encode.h +70 -0
  840. data/third_party/upb/upb/json_decode.h +4 -15
  841. data/third_party/upb/upb/json_encode.h +4 -33
  842. data/third_party/upb/upb/lex/atoi.c +68 -0
  843. data/third_party/upb/upb/lex/atoi.h +53 -0
  844. data/third_party/upb/upb/{upb.c → lex/round_trip.c} +2 -11
  845. data/third_party/upb/upb/{internal/upb.h → lex/round_trip.h} +17 -30
  846. data/third_party/upb/upb/lex/strtod.c +97 -0
  847. data/third_party/upb/upb/lex/strtod.h +46 -0
  848. data/third_party/upb/upb/lex/unicode.c +57 -0
  849. data/third_party/upb/upb/lex/unicode.h +77 -0
  850. data/third_party/upb/upb/map.h +4 -85
  851. data/third_party/upb/upb/mem/alloc.c +47 -0
  852. data/third_party/upb/upb/mem/alloc.h +98 -0
  853. data/third_party/upb/upb/mem/arena.c +367 -0
  854. data/third_party/upb/upb/mem/arena.h +160 -0
  855. data/third_party/upb/upb/mem/arena_internal.h +114 -0
  856. data/third_party/upb/upb/message/accessors.c +68 -0
  857. data/third_party/upb/upb/message/accessors.h +379 -0
  858. data/third_party/upb/upb/message/accessors_internal.h +325 -0
  859. data/third_party/upb/upb/message/extension_internal.h +83 -0
  860. data/third_party/upb/upb/message/internal.h +135 -0
  861. data/third_party/upb/upb/message/message.c +180 -0
  862. data/third_party/upb/upb/message/message.h +69 -0
  863. data/third_party/upb/upb/mini_table/common.c +128 -0
  864. data/third_party/upb/upb/mini_table/common.h +170 -0
  865. data/third_party/upb/upb/mini_table/common_internal.h +111 -0
  866. data/third_party/upb/upb/{mini_table.c → mini_table/decode.c} +513 -533
  867. data/third_party/upb/upb/mini_table/decode.h +179 -0
  868. data/third_party/upb/upb/mini_table/encode.c +300 -0
  869. data/third_party/upb/upb/mini_table/encode_internal.h +111 -0
  870. data/third_party/upb/upb/{mini_table.hpp → mini_table/encode_internal.hpp} +32 -8
  871. data/third_party/upb/upb/mini_table/enum_internal.h +88 -0
  872. data/third_party/upb/upb/mini_table/extension_internal.h +47 -0
  873. data/third_party/upb/upb/{extension_registry.c → mini_table/extension_registry.c} +27 -24
  874. data/third_party/upb/upb/mini_table/extension_registry.h +104 -0
  875. data/third_party/upb/upb/mini_table/field_internal.h +192 -0
  876. data/third_party/upb/upb/mini_table/file_internal.h +47 -0
  877. data/third_party/upb/upb/mini_table/message_internal.h +136 -0
  878. data/third_party/upb/upb/mini_table/sub_internal.h +38 -0
  879. data/third_party/upb/upb/mini_table/types.h +40 -0
  880. data/third_party/upb/upb/mini_table.h +4 -157
  881. data/third_party/upb/upb/msg.h +3 -38
  882. data/third_party/upb/upb/port/atomic.h +101 -0
  883. data/third_party/upb/upb/{port_def.inc → port/def.inc} +94 -27
  884. data/third_party/upb/upb/{port_undef.inc → port/undef.inc} +13 -3
  885. data/third_party/upb/upb/{internal → port}/vsnprintf_compat.h +5 -7
  886. data/third_party/upb/upb/reflection/common.h +67 -0
  887. data/third_party/upb/upb/reflection/def.h +42 -0
  888. data/third_party/upb/upb/reflection/def.hpp +610 -0
  889. data/third_party/upb/upb/reflection/def_builder.c +357 -0
  890. data/third_party/upb/upb/reflection/def_builder_internal.h +157 -0
  891. data/third_party/upb/upb/reflection/def_pool.c +462 -0
  892. data/third_party/upb/upb/reflection/def_pool.h +108 -0
  893. data/third_party/upb/upb/reflection/def_pool_internal.h +77 -0
  894. data/third_party/upb/upb/reflection/def_type.c +50 -0
  895. data/third_party/upb/upb/reflection/def_type.h +81 -0
  896. data/third_party/upb/upb/reflection/desc_state.c +53 -0
  897. data/third_party/upb/upb/reflection/desc_state_internal.h +64 -0
  898. data/third_party/upb/upb/reflection/enum_def.c +310 -0
  899. data/third_party/upb/upb/reflection/enum_def.h +80 -0
  900. data/third_party/upb/upb/reflection/enum_def_internal.h +56 -0
  901. data/third_party/upb/upb/reflection/enum_reserved_range.c +84 -0
  902. data/third_party/upb/upb/reflection/enum_reserved_range.h +51 -0
  903. data/third_party/upb/upb/reflection/enum_reserved_range_internal.h +55 -0
  904. data/third_party/upb/upb/reflection/enum_value_def.c +144 -0
  905. data/third_party/upb/upb/reflection/enum_value_def.h +57 -0
  906. data/third_party/upb/upb/reflection/enum_value_def_internal.h +57 -0
  907. data/third_party/upb/upb/reflection/extension_range.c +93 -0
  908. data/third_party/upb/upb/reflection/extension_range.h +55 -0
  909. data/third_party/upb/upb/reflection/extension_range_internal.h +54 -0
  910. data/third_party/upb/upb/reflection/field_def.c +930 -0
  911. data/third_party/upb/upb/reflection/field_def.h +91 -0
  912. data/third_party/upb/upb/reflection/field_def_internal.h +76 -0
  913. data/third_party/upb/upb/reflection/file_def.c +370 -0
  914. data/third_party/upb/upb/reflection/file_def.h +77 -0
  915. data/third_party/upb/upb/reflection/file_def_internal.h +57 -0
  916. data/third_party/upb/upb/reflection/message.c +233 -0
  917. data/third_party/upb/upb/reflection/message.h +102 -0
  918. data/third_party/upb/upb/reflection/message.hpp +37 -0
  919. data/third_party/upb/upb/reflection/message_def.c +718 -0
  920. data/third_party/upb/upb/reflection/message_def.h +174 -0
  921. data/third_party/upb/upb/reflection/message_def_internal.h +63 -0
  922. data/third_party/upb/upb/reflection/message_reserved_range.c +81 -0
  923. data/third_party/upb/upb/reflection/message_reserved_range.h +51 -0
  924. data/third_party/upb/upb/reflection/message_reserved_range_internal.h +55 -0
  925. data/third_party/upb/upb/reflection/method_def.c +124 -0
  926. data/third_party/upb/upb/reflection/method_def.h +59 -0
  927. data/third_party/upb/upb/reflection/method_def_internal.h +53 -0
  928. data/third_party/upb/upb/reflection/oneof_def.c +226 -0
  929. data/third_party/upb/upb/reflection/oneof_def.h +66 -0
  930. data/third_party/upb/upb/reflection/oneof_def_internal.h +57 -0
  931. data/third_party/upb/upb/reflection/service_def.c +128 -0
  932. data/third_party/upb/upb/reflection/service_def.h +60 -0
  933. data/third_party/upb/upb/reflection/service_def_internal.h +53 -0
  934. data/third_party/upb/upb/reflection.h +4 -78
  935. data/third_party/upb/upb/reflection.hpp +3 -7
  936. data/third_party/upb/upb/status.h +4 -34
  937. data/third_party/upb/upb/{collections.h → string_view.h} +7 -7
  938. data/third_party/upb/upb/{text_encode.c → text/encode.c} +74 -70
  939. data/third_party/upb/upb/text/encode.h +69 -0
  940. data/third_party/upb/upb/text_encode.h +4 -32
  941. data/third_party/upb/upb/upb.h +6 -151
  942. data/third_party/upb/upb/upb.hpp +10 -18
  943. data/third_party/upb/upb/wire/common.h +44 -0
  944. data/third_party/upb/upb/wire/common_internal.h +50 -0
  945. data/third_party/upb/upb/wire/decode.c +1343 -0
  946. data/third_party/upb/upb/wire/decode.h +108 -0
  947. data/third_party/upb/upb/{decode_fast.c → wire/decode_fast.c} +184 -225
  948. data/third_party/upb/upb/{decode_fast.h → wire/decode_fast.h} +21 -7
  949. data/third_party/upb/upb/{internal/decode.h → wire/decode_internal.h} +44 -92
  950. data/third_party/upb/upb/{encode.c → wire/encode.c} +114 -95
  951. data/third_party/upb/upb/wire/encode.h +92 -0
  952. data/third_party/upb/upb/wire/eps_copy_input_stream.c +39 -0
  953. data/third_party/upb/upb/wire/eps_copy_input_stream.h +425 -0
  954. data/third_party/upb/upb/wire/reader.c +67 -0
  955. data/third_party/upb/upb/wire/reader.h +227 -0
  956. data/third_party/upb/upb/wire/swap_internal.h +63 -0
  957. data/third_party/upb/upb/wire/types.h +41 -0
  958. data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-neon.c +1 -1
  959. data/third_party/{upb/third_party/utf8_range → utf8_range}/utf8_range.h +12 -0
  960. metadata +157 -40
  961. data/src/core/ext/transport/chttp2/transport/context_list.cc +0 -71
  962. data/src/core/ext/transport/chttp2/transport/context_list.h +0 -54
  963. data/third_party/upb/upb/arena.c +0 -277
  964. data/third_party/upb/upb/decode.c +0 -1221
  965. data/third_party/upb/upb/def.c +0 -3269
  966. data/third_party/upb/upb/internal/table.h +0 -385
  967. data/third_party/upb/upb/msg.c +0 -368
  968. data/third_party/upb/upb/msg_internal.h +0 -837
  969. data/third_party/upb/upb/reflection.c +0 -323
  970. /data/third_party/{upb/third_party/utf8_range → utf8_range}/naive.c +0 -0
  971. /data/third_party/{upb/third_party/utf8_range → utf8_range}/range2-sse.c +0 -0
@@ -34,6 +34,7 @@
34
34
  #include "src/core/lib/gprpp/sync.h"
35
35
  #include "src/core/lib/iomgr/exec_ctx.h"
36
36
  #include "src/core/lib/json/json.h"
37
+ #include "src/core/lib/json/json_writer.h"
37
38
 
38
39
  namespace grpc_core {
39
40
  namespace channelz {
@@ -111,7 +112,7 @@ std::string ChannelzRegistry::InternalGetTopChannels(
111
112
  }
112
113
  if (node_after_pagination_limit == nullptr) object["end"] = true;
113
114
  Json json(std::move(object));
114
- return json.Dump();
115
+ return JsonDump(json);
115
116
  }
116
117
 
117
118
  std::string ChannelzRegistry::InternalGetServers(intptr_t start_server_id) {
@@ -150,7 +151,7 @@ std::string ChannelzRegistry::InternalGetServers(intptr_t start_server_id) {
150
151
  }
151
152
  if (node_after_pagination_limit == nullptr) object["end"] = true;
152
153
  Json json(std::move(object));
153
- return json.Dump();
154
+ return JsonDump(json);
154
155
  }
155
156
 
156
157
  void ChannelzRegistry::InternalLogAllEntities() {
@@ -202,7 +203,7 @@ char* grpc_channelz_get_server(intptr_t server_id) {
202
203
  grpc_core::Json json = grpc_core::Json::Object{
203
204
  {"server", server_node->RenderJson()},
204
205
  };
205
- return gpr_strdup(json.Dump().c_str());
206
+ return gpr_strdup(JsonDump(json).c_str());
206
207
  }
207
208
 
208
209
  char* grpc_channelz_get_server_sockets(intptr_t server_id,
@@ -241,7 +242,7 @@ char* grpc_channelz_get_channel(intptr_t channel_id) {
241
242
  grpc_core::Json json = grpc_core::Json::Object{
242
243
  {"channel", channel_node->RenderJson()},
243
244
  };
244
- return gpr_strdup(json.Dump().c_str());
245
+ return gpr_strdup(JsonDump(json).c_str());
245
246
  }
246
247
 
247
248
  char* grpc_channelz_get_subchannel(intptr_t subchannel_id) {
@@ -257,7 +258,7 @@ char* grpc_channelz_get_subchannel(intptr_t subchannel_id) {
257
258
  grpc_core::Json json = grpc_core::Json::Object{
258
259
  {"subchannel", subchannel_node->RenderJson()},
259
260
  };
260
- return gpr_strdup(json.Dump().c_str());
261
+ return gpr_strdup(JsonDump(json).c_str());
261
262
  }
262
263
 
263
264
  char* grpc_channelz_get_socket(intptr_t socket_id) {
@@ -273,5 +274,5 @@ char* grpc_channelz_get_socket(intptr_t socket_id) {
273
274
  grpc_core::Json json = grpc_core::Json::Object{
274
275
  {"socket", socket_node->RenderJson()},
275
276
  };
276
- return gpr_strdup(json.Dump().c_str());
277
+ return gpr_strdup(JsonDump(json).c_str());
277
278
  }
@@ -56,8 +56,8 @@
56
56
  #include "src/core/lib/promise/activity.h"
57
57
  #include "src/core/lib/promise/arena_promise.h"
58
58
  #include "src/core/lib/promise/context.h"
59
- #include "src/core/lib/promise/detail/basic_join.h"
60
59
  #include "src/core/lib/promise/detail/basic_seq.h"
60
+ #include "src/core/lib/promise/detail/status.h"
61
61
  #include "src/core/lib/promise/for_each.h"
62
62
  #include "src/core/lib/promise/if.h"
63
63
  #include "src/core/lib/promise/latch.h"
@@ -69,7 +69,6 @@
69
69
  #include "src/core/lib/promise/promise.h"
70
70
  #include "src/core/lib/promise/race.h"
71
71
  #include "src/core/lib/promise/seq.h"
72
- #include "src/core/lib/promise/try_join.h"
73
72
  #include "src/core/lib/promise/try_seq.h"
74
73
  #include "src/core/lib/resource_quota/arena.h"
75
74
  #include "src/core/lib/slice/slice.h"
@@ -321,7 +320,8 @@ class ConnectedChannelStream : public Orphanable {
321
320
  }
322
321
 
323
322
  // Returns a promise that implements the receive message loop.
324
- auto RecvMessages(PipeSender<MessageHandle>* incoming_messages);
323
+ auto RecvMessages(PipeSender<MessageHandle>* incoming_messages,
324
+ bool cancel_on_error);
325
325
  // Returns a promise that implements the send message loop.
326
326
  auto SendMessages(PipeReceiver<MessageHandle>* outgoing_messages);
327
327
 
@@ -374,12 +374,12 @@ class ConnectedChannelStream : public Orphanable {
374
374
  };
375
375
 
376
376
  auto ConnectedChannelStream::RecvMessages(
377
- PipeSender<MessageHandle>* incoming_messages) {
378
- return Loop([self = InternalRef(),
377
+ PipeSender<MessageHandle>* incoming_messages, bool cancel_on_error) {
378
+ return Loop([self = InternalRef(), cancel_on_error,
379
379
  incoming_messages = std::move(*incoming_messages)]() mutable {
380
380
  return Seq(
381
381
  GetContext<BatchBuilder>()->ReceiveMessage(self->batch_target()),
382
- [&incoming_messages](
382
+ [cancel_on_error, &incoming_messages](
383
383
  absl::StatusOr<absl::optional<MessageHandle>> status) mutable {
384
384
  bool has_message = status.ok() && status->has_value();
385
385
  auto publish_message = [&incoming_messages, &status]() {
@@ -405,7 +405,8 @@ auto ConnectedChannelStream::RecvMessages(
405
405
  return Continue{};
406
406
  });
407
407
  };
408
- auto publish_close = [&status]() mutable {
408
+ auto publish_close = [cancel_on_error, &incoming_messages,
409
+ &status]() mutable {
409
410
  if (grpc_call_trace.enabled()) {
410
411
  gpr_log(GPR_INFO,
411
412
  "%s[connected] RecvMessage: reached end of stream with "
@@ -413,6 +414,9 @@ auto ConnectedChannelStream::RecvMessages(
413
414
  Activity::current()->DebugTag().c_str(),
414
415
  status.status().ToString().c_str());
415
416
  }
417
+ if (cancel_on_error && !status.ok()) {
418
+ incoming_messages.CloseWithError();
419
+ }
416
420
  return Immediate(LoopCtl<absl::Status>(status.status()));
417
421
  };
418
422
  return If(has_message, std::move(publish_message),
@@ -442,9 +446,13 @@ ArenaPromise<ServerMetadataHandle> MakeClientCallPromise(
442
446
  grpc_transport_init_stream(transport, stream->stream(),
443
447
  stream->stream_refcount(), nullptr,
444
448
  GetContext<Arena>());
445
- grpc_transport_set_pops(transport, stream->stream(),
446
- GetContext<CallContext>()->polling_entity());
447
449
  auto* party = static_cast<Party*>(Activity::current());
450
+ party->Spawn(
451
+ "set_polling_entity", call_args.polling_entity->Wait(),
452
+ [transport,
453
+ stream = stream->InternalRef()](grpc_polling_entity polling_entity) {
454
+ grpc_transport_set_pops(transport, stream->stream(), &polling_entity);
455
+ });
448
456
  // Start a loop to send messages from client_to_server_messages to the
449
457
  // transport. When the pipe closes and the loop completes, send a trailing
450
458
  // metadata batch to close the stream.
@@ -523,14 +531,44 @@ ArenaPromise<ServerMetadataHandle> MakeClientCallPromise(
523
531
  // complete (or one fails).
524
532
  // Next: receive trailing metadata, and return that up the stack.
525
533
  auto recv_messages =
526
- stream->RecvMessages(call_args.server_to_client_messages);
527
- return Map(TrySeq(TryJoin(std::move(send_initial_metadata),
528
- std::move(recv_messages)),
529
- std::move(recv_trailing_metadata)),
530
- [stream = std::move(stream)](ServerMetadataHandle result) {
531
- stream->set_finished();
532
- return result;
533
- });
534
+ stream->RecvMessages(call_args.server_to_client_messages, false);
535
+ return Map(
536
+ [send_initial_metadata = std::move(send_initial_metadata),
537
+ recv_messages = std::move(recv_messages),
538
+ recv_trailing_metadata = std::move(recv_trailing_metadata),
539
+ done_send_initial_metadata = false, done_recv_messages = false,
540
+ done_recv_trailing_metadata =
541
+ false]() mutable -> Poll<ServerMetadataHandle> {
542
+ if (!done_send_initial_metadata) {
543
+ auto p = send_initial_metadata();
544
+ if (auto* r = p.value_if_ready()) {
545
+ done_send_initial_metadata = true;
546
+ if (!r->ok()) return StatusCast<ServerMetadataHandle>(*r);
547
+ }
548
+ }
549
+ if (!done_recv_messages) {
550
+ auto p = recv_messages();
551
+ if (auto* r = p.value_if_ready()) {
552
+ // NOTE: ignore errors here, they'll be collected in the
553
+ // recv_trailing_metadata.
554
+ done_recv_messages = true;
555
+ } else {
556
+ return Pending{};
557
+ }
558
+ }
559
+ if (!done_recv_trailing_metadata) {
560
+ auto p = recv_trailing_metadata();
561
+ if (auto* r = p.value_if_ready()) {
562
+ done_recv_trailing_metadata = true;
563
+ return std::move(*r);
564
+ }
565
+ }
566
+ return Pending{};
567
+ },
568
+ [stream = std::move(stream)](ServerMetadataHandle result) {
569
+ stream->set_finished();
570
+ return result;
571
+ });
534
572
  }
535
573
  #endif
536
574
 
@@ -547,9 +585,6 @@ ArenaPromise<ServerMetadataHandle> MakeServerCallPromise(
547
585
  transport, stream->stream(), stream->stream_refcount(),
548
586
  GetContext<CallContext>()->server_call_context()->server_stream_data(),
549
587
  GetContext<Arena>());
550
- grpc_transport_set_pops(transport, stream->stream(),
551
- GetContext<CallContext>()->polling_entity());
552
-
553
588
  auto* party = static_cast<Party*>(Activity::current());
554
589
 
555
590
  // Arifacts we need for the lifetime of the call.
@@ -558,11 +593,19 @@ ArenaPromise<ServerMetadataHandle> MakeServerCallPromise(
558
593
  Pipe<MessageHandle> client_to_server;
559
594
  Pipe<ServerMetadataHandle> server_initial_metadata;
560
595
  Latch<ServerMetadataHandle> failure_latch;
596
+ Latch<grpc_polling_entity> polling_entity_latch;
561
597
  bool sent_initial_metadata = false;
562
598
  bool sent_trailing_metadata = false;
563
599
  };
564
600
  auto* call_data = GetContext<Arena>()->ManagedNew<CallData>();
565
601
 
602
+ party->Spawn(
603
+ "set_polling_entity", call_data->polling_entity_latch.Wait(),
604
+ [transport,
605
+ stream = stream->InternalRef()](grpc_polling_entity polling_entity) {
606
+ grpc_transport_set_pops(transport, stream->stream(), &polling_entity);
607
+ });
608
+
566
609
  auto server_to_client_empty =
567
610
  call_data->server_to_client.receiver.AwaitEmpty();
568
611
 
@@ -580,6 +623,7 @@ ArenaPromise<ServerMetadataHandle> MakeServerCallPromise(
580
623
  auto call_promise = next_promise_factory(CallArgs{
581
624
  std::move(client_initial_metadata),
582
625
  ClientInitialMetadataOutstandingToken::Empty(),
626
+ &call_data->polling_entity_latch,
583
627
  &call_data->server_initial_metadata.sender,
584
628
  &call_data->client_to_server.receiver,
585
629
  &call_data->server_to_client.sender,
@@ -680,7 +724,7 @@ ArenaPromise<ServerMetadataHandle> MakeServerCallPromise(
680
724
  "recv_messages",
681
725
  Race(
682
726
  Map(stream->WaitFinished(), [](Empty) { return absl::OkStatus(); }),
683
- Map(stream->RecvMessages(&call_data->client_to_server.sender),
727
+ Map(stream->RecvMessages(&call_data->client_to_server.sender, true),
684
728
  [failure_latch = &call_data->failure_latch](absl::Status status) {
685
729
  if (!status.ok() && !failure_latch->is_set()) {
686
730
  failure_latch->Set(ServerMetadataFromStatus(status));
@@ -769,12 +813,23 @@ ArenaPromise<ServerMetadataHandle> MakeServerCallPromise(
769
813
  // (allowing the call code to decide on what signalling to give the
770
814
  // application).
771
815
 
772
- return Map(Seq(std::move(recv_initial_metadata_then_run_promise),
773
- std::move(send_trailing_metadata)),
774
- [stream = std::move(stream)](ServerMetadataHandle md) {
775
- stream->set_finished();
776
- return md;
777
- });
816
+ struct CleanupPollingEntityLatch {
817
+ void operator()(Latch<grpc_polling_entity>* latch) {
818
+ if (!latch->is_set()) latch->Set(grpc_polling_entity());
819
+ }
820
+ };
821
+ auto cleanup_polling_entity_latch =
822
+ std::unique_ptr<Latch<grpc_polling_entity>, CleanupPollingEntityLatch>(
823
+ &call_data->polling_entity_latch);
824
+
825
+ return Map(
826
+ Seq(std::move(recv_initial_metadata_then_run_promise),
827
+ std::move(send_trailing_metadata)),
828
+ [cleanup_polling_entity_latch = std::move(cleanup_polling_entity_latch),
829
+ stream = std::move(stream)](ServerMetadataHandle md) {
830
+ stream->set_finished();
831
+ return md;
832
+ });
778
833
  }
779
834
  #endif
780
835
 
@@ -16,8 +16,6 @@
16
16
 
17
17
  #include "src/core/lib/channel/promise_based_filter.h"
18
18
 
19
- #include <inttypes.h>
20
-
21
19
  #include <algorithm>
22
20
  #include <initializer_list>
23
21
  #include <memory>
@@ -245,10 +243,6 @@ void BaseCallData::CapturedBatch::CancelWith(grpc_error_handle error,
245
243
  auto* batch = std::exchange(batch_, nullptr);
246
244
  GPR_ASSERT(batch != nullptr);
247
245
  uintptr_t& refcnt = *RefCountField(batch);
248
- gpr_log(GPR_DEBUG, "%sCancelWith: %p refs=%" PRIdPTR " err=%s [%s]",
249
- releaser->call()->DebugTag().c_str(), batch, refcnt,
250
- error.ToString().c_str(),
251
- grpc_transport_stream_op_batch_string(batch, false).c_str());
252
246
  if (refcnt == 0) {
253
247
  // refcnt==0 ==> cancelled
254
248
  if (grpc_trace_channel.enabled()) {
@@ -1583,7 +1577,7 @@ void ClientCallData::StartPromise(Flusher* flusher) {
1583
1577
  promise_ = filter->MakeCallPromise(
1584
1578
  CallArgs{WrapMetadata(send_initial_metadata_batch_->payload
1585
1579
  ->send_initial_metadata.send_initial_metadata),
1586
- std::move(initial_metadata_outstanding_token_),
1580
+ std::move(initial_metadata_outstanding_token_), nullptr,
1587
1581
  server_initial_metadata_pipe() == nullptr
1588
1582
  ? nullptr
1589
1583
  : &server_initial_metadata_pipe()->sender,
@@ -2373,7 +2367,7 @@ void ServerCallData::RecvInitialMetadataReady(grpc_error_handle error) {
2373
2367
  FakeActivity(this).Run([this, filter] {
2374
2368
  promise_ = filter->MakeCallPromise(
2375
2369
  CallArgs{WrapMetadata(recv_initial_metadata_),
2376
- ClientInitialMetadataOutstandingToken::Empty(),
2370
+ ClientInitialMetadataOutstandingToken::Empty(), nullptr,
2377
2371
  server_initial_metadata_pipe() == nullptr
2378
2372
  ? nullptr
2379
2373
  : &server_initial_metadata_pipe()->sender,
@@ -24,6 +24,7 @@
24
24
 
25
25
  #include <string>
26
26
  #include <type_traits>
27
+ #include <utility>
27
28
 
28
29
  #include "absl/strings/string_view.h"
29
30
 
@@ -77,12 +78,17 @@ void TraceFlagList::Add(TraceFlag* flag) {
77
78
 
78
79
  void TraceFlagList::LogAllTracers() {
79
80
  gpr_log(GPR_DEBUG, "available tracers:");
80
- TraceFlag* t;
81
- for (t = root_tracer_; t != nullptr; t = t->next_tracer_) {
81
+ for (TraceFlag* t = root_tracer_; t != nullptr; t = t->next_tracer_) {
82
82
  gpr_log(GPR_DEBUG, "\t%s", t->name_);
83
83
  }
84
84
  }
85
85
 
86
+ void TraceFlagList::SaveTo(std::map<std::string, bool>& values) {
87
+ for (TraceFlag* t = root_tracer_; t != nullptr; t = t->next_tracer_) {
88
+ values[t->name_] = t->enabled();
89
+ }
90
+ }
91
+
86
92
  // Flags register themselves on the list during construction
87
93
  TraceFlag::TraceFlag(bool default_enabled, const char* name) : name_(name) {
88
94
  static_assert(std::is_trivially_destructible<TraceFlag>::value,
@@ -91,6 +97,14 @@ TraceFlag::TraceFlag(bool default_enabled, const char* name) : name_(name) {
91
97
  TraceFlagList::Add(this);
92
98
  }
93
99
 
100
+ SavedTraceFlags::SavedTraceFlags() { TraceFlagList::SaveTo(values_); }
101
+
102
+ void SavedTraceFlags::Restore() {
103
+ for (const auto& flag : values_) {
104
+ TraceFlagList::Set(flag.first.c_str(), flag.second);
105
+ }
106
+ }
107
+
94
108
  } // namespace grpc_core
95
109
 
96
110
  static void add(const char* beg, const char* end, char*** ss, size_t* ns) {
@@ -138,11 +152,6 @@ static void parse(const char* s) {
138
152
  gpr_free(strings);
139
153
  }
140
154
 
141
- void grpc_tracer_init(const char* env_var_name) {
142
- (void)env_var_name; // suppress unused variable error
143
- grpc_tracer_init();
144
- }
145
-
146
155
  void grpc_tracer_init() {
147
156
  parse(std::string(grpc_core::ConfigVars::Get().Trace()).c_str());
148
157
  }
@@ -22,10 +22,8 @@
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
24
  #include <atomic>
25
-
26
- // TODO(veblush): Remove this deprecated function once codes depending on this
27
- // function are updated in the internal repo.
28
- void grpc_tracer_init(const char* env_var_name);
25
+ #include <map>
26
+ #include <string>
29
27
 
30
28
  void grpc_tracer_init();
31
29
  void grpc_tracer_shutdown(void);
@@ -37,6 +35,7 @@ class TraceFlagList {
37
35
  public:
38
36
  static bool Set(const char* name, bool enabled);
39
37
  static void Add(TraceFlag* flag);
38
+ static void SaveTo(std::map<std::string, bool>& values);
40
39
 
41
40
  private:
42
41
  static void LogAllTracers();
@@ -101,6 +100,15 @@ class DebugOnlyTraceFlag {
101
100
  };
102
101
  #endif
103
102
 
103
+ class SavedTraceFlags {
104
+ public:
105
+ SavedTraceFlags();
106
+ void Restore();
107
+
108
+ private:
109
+ std::map<std::string, bool> values_;
110
+ };
111
+
104
112
  } // namespace grpc_core
105
113
 
106
114
  #endif // GRPC_SRC_CORE_LIB_DEBUG_TRACE_H
@@ -41,7 +41,6 @@
41
41
  #include "src/core/lib/event_engine/posix.h"
42
42
  #include "src/core/lib/event_engine/posix_engine/tcp_socket_utils.h"
43
43
  #include "src/core/lib/event_engine/posix_engine/timer.h"
44
- #include "src/core/lib/event_engine/shim.h"
45
44
  #include "src/core/lib/event_engine/tcp_socket_utils.h"
46
45
  #include "src/core/lib/event_engine/trace.h"
47
46
  #include "src/core/lib/event_engine/utils.h"
@@ -61,15 +60,20 @@
61
60
 
62
61
  // IWYU pragma: no_include <ratio>
63
62
 
63
+ // TODO(eryu): remove this GRPC_CFSTREAM condition when the CFEngine is ready.
64
+ // The posix poller currently crashes iOS.
65
+ #if defined(GRPC_POSIX_SOCKET_TCP) && !defined(GRPC_CFSTREAM) && \
66
+ !defined(GRPC_DO_NOT_INSTANTIATE_POSIX_POLLER)
67
+ #define GRPC_PLATFORM_SUPPORTS_POSIX_POLLING true
68
+ #else
69
+ #define GRPC_PLATFORM_SUPPORTS_POSIX_POLLING false
70
+ #endif
71
+
64
72
  using namespace std::chrono_literals;
65
73
 
66
74
  namespace grpc_event_engine {
67
75
  namespace experimental {
68
76
 
69
- bool NeedPosixEngine() {
70
- return UseEventEngineClient() || UseEventEngineListener();
71
- }
72
-
73
77
  #ifdef GRPC_POSIX_SOCKET_TCP
74
78
 
75
79
  void AsyncConnect::Start(EventEngine::Duration timeout) {
@@ -340,25 +344,25 @@ PosixEventEngine::PosixEventEngine(PosixEventPoller* poller)
340
344
  : connection_shards_(std::max(2 * gpr_cpu_num_cores(), 1u)),
341
345
  executor_(std::make_shared<ThreadPool>()),
342
346
  timer_manager_(executor_) {
343
- if (NeedPosixEngine()) {
344
- poller_manager_ = std::make_shared<PosixEnginePollerManager>(poller);
345
- }
347
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
348
+ poller_manager_ = std::make_shared<PosixEnginePollerManager>(poller);
349
+ #endif
346
350
  }
347
351
 
348
352
  PosixEventEngine::PosixEventEngine()
349
353
  : connection_shards_(std::max(2 * gpr_cpu_num_cores(), 1u)),
350
354
  executor_(std::make_shared<ThreadPool>()),
351
355
  timer_manager_(executor_) {
352
- if (NeedPosixEngine()) {
353
- poller_manager_ = std::make_shared<PosixEnginePollerManager>(executor_);
354
- // The threadpool must be instantiated after the poller otherwise, the
355
- // process will deadlock when forking.
356
- if (poller_manager_->Poller() != nullptr) {
357
- executor_->Run([poller_manager = poller_manager_]() {
358
- PollerWorkInternal(poller_manager);
359
- });
360
- }
356
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
357
+ poller_manager_ = std::make_shared<PosixEnginePollerManager>(executor_);
358
+ // The threadpool must be instantiated after the poller otherwise, the
359
+ // process will deadlock when forking.
360
+ if (poller_manager_->Poller() != nullptr) {
361
+ executor_->Run([poller_manager = poller_manager_]() {
362
+ PollerWorkInternal(poller_manager);
363
+ });
361
364
  }
365
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
362
366
  }
363
367
 
364
368
  void PosixEventEngine::PollerWorkInternal(
@@ -429,11 +433,11 @@ PosixEventEngine::~PosixEventEngine() {
429
433
  GPR_ASSERT(GPR_LIKELY(known_handles_.empty()));
430
434
  }
431
435
  timer_manager_.Shutdown();
432
- #ifdef GRPC_POSIX_SOCKET_TCP
436
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
433
437
  if (poller_manager_ != nullptr) {
434
438
  poller_manager_->TriggerShutdown();
435
439
  }
436
- #endif // GRPC_POSIX_SOCKET_TCP
440
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
437
441
  executor_->Quiesce();
438
442
  }
439
443
 
@@ -490,7 +494,7 @@ std::unique_ptr<EventEngine::DNSResolver> PosixEventEngine::GetDNSResolver(
490
494
  bool PosixEventEngine::IsWorkerThread() { grpc_core::Crash("unimplemented"); }
491
495
 
492
496
  bool PosixEventEngine::CancelConnect(EventEngine::ConnectionHandle handle) {
493
- #ifdef GRPC_POSIX_SOCKET_TCP
497
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
494
498
  int connection_handle = handle.keys[0];
495
499
  if (connection_handle <= 0) {
496
500
  return false;
@@ -539,20 +543,17 @@ bool PosixEventEngine::CancelConnect(EventEngine::ConnectionHandle handle) {
539
543
  delete ac;
540
544
  }
541
545
  return connection_cancel_success;
542
- #else // GRPC_POSIX_SOCKET_TCP
546
+ #else // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
543
547
  grpc_core::Crash(
544
548
  "EventEngine::CancelConnect is not supported on this platform");
545
- #endif // GRPC_POSIX_SOCKET_TCP
549
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
546
550
  }
547
551
 
548
552
  EventEngine::ConnectionHandle PosixEventEngine::Connect(
549
553
  OnConnectCallback on_connect, const ResolvedAddress& addr,
550
554
  const EndpointConfig& args, MemoryAllocator memory_allocator,
551
555
  Duration timeout) {
552
- if (!NeedPosixEngine()) {
553
- grpc_core::Crash("unimplemented");
554
- }
555
- #ifdef GRPC_POSIX_SOCKET_TCP
556
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
556
557
  GPR_ASSERT(poller_manager_ != nullptr);
557
558
  PosixTcpOptions options = TcpOptionsFromEndpointConfig(args);
558
559
  absl::StatusOr<PosixSocketWrapper::PosixSocketCreateResult> socket =
@@ -565,19 +566,16 @@ EventEngine::ConnectionHandle PosixEventEngine::Connect(
565
566
  return ConnectInternal((*socket).sock, std::move(on_connect),
566
567
  (*socket).mapped_target_addr,
567
568
  std::move(memory_allocator), options, timeout);
568
- #else // GRPC_POSIX_SOCKET_TCP
569
+ #else // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
569
570
  grpc_core::Crash("EventEngine::Connect is not supported on this platform");
570
- #endif // GRPC_POSIX_SOCKET_TCP
571
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
571
572
  }
572
573
 
573
574
  std::unique_ptr<PosixEndpointWithFdSupport>
574
575
  PosixEventEngine::CreatePosixEndpointFromFd(int fd,
575
576
  const EndpointConfig& config,
576
577
  MemoryAllocator memory_allocator) {
577
- if (!NeedPosixEngine()) {
578
- grpc_core::Crash("unimplemented");
579
- }
580
- #ifdef GRPC_POSIX_SOCKET_TCP
578
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
581
579
  GPR_DEBUG_ASSERT(fd > 0);
582
580
  PosixEventPoller* poller = poller_manager_->Poller();
583
581
  GPR_DEBUG_ASSERT(poller != nullptr);
@@ -586,11 +584,11 @@ PosixEventEngine::CreatePosixEndpointFromFd(int fd,
586
584
  return CreatePosixEndpoint(handle, nullptr, shared_from_this(),
587
585
  std::move(memory_allocator),
588
586
  TcpOptionsFromEndpointConfig(config));
589
- #else // GRPC_POSIX_SOCKET_TCP
587
+ #else // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
590
588
  grpc_core::Crash(
591
589
  "PosixEventEngine::CreatePosixEndpointFromFd is not supported on "
592
590
  "this platform");
593
- #endif // GRPC_POSIX_SOCKET_TCP
591
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
594
592
  }
595
593
 
596
594
  absl::StatusOr<std::unique_ptr<EventEngine::Listener>>
@@ -599,7 +597,7 @@ PosixEventEngine::CreateListener(
599
597
  absl::AnyInvocable<void(absl::Status)> on_shutdown,
600
598
  const EndpointConfig& config,
601
599
  std::unique_ptr<MemoryAllocatorFactory> memory_allocator_factory) {
602
- #ifdef GRPC_POSIX_SOCKET_TCP
600
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
603
601
  PosixEventEngineWithFdSupport::PosixAcceptCallback posix_on_accept =
604
602
  [on_accept_cb = std::move(on_accept)](
605
603
  int /*listener_fd*/, std::unique_ptr<EventEngine::Endpoint> ep,
@@ -611,10 +609,10 @@ PosixEventEngine::CreateListener(
611
609
  std::move(posix_on_accept), std::move(on_shutdown), config,
612
610
  std::move(memory_allocator_factory), poller_manager_->Poller(),
613
611
  shared_from_this());
614
- #else // GRPC_POSIX_SOCKET_TCP
612
+ #else // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
615
613
  grpc_core::Crash(
616
614
  "EventEngine::CreateListener is not supported on this platform");
617
- #endif // GRPC_POSIX_SOCKET_TCP
615
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
618
616
  }
619
617
 
620
618
  absl::StatusOr<std::unique_ptr<PosixListenerWithFdSupport>>
@@ -623,18 +621,15 @@ PosixEventEngine::CreatePosixListener(
623
621
  absl::AnyInvocable<void(absl::Status)> on_shutdown,
624
622
  const EndpointConfig& config,
625
623
  std::unique_ptr<MemoryAllocatorFactory> memory_allocator_factory) {
626
- if (!NeedPosixEngine()) {
627
- grpc_core::Crash("unimplemented");
628
- }
629
- #ifdef GRPC_POSIX_SOCKET_TCP
624
+ #if GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
630
625
  return std::make_unique<PosixEngineListener>(
631
626
  std::move(on_accept), std::move(on_shutdown), config,
632
627
  std::move(memory_allocator_factory), poller_manager_->Poller(),
633
628
  shared_from_this());
634
- #else // GRPC_POSIX_SOCKET_TCP
629
+ #else // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
635
630
  grpc_core::Crash(
636
631
  "EventEngine::CreateListener is not supported on this platform");
637
- #endif // GRPC_POSIX_SOCKET_TCP
632
+ #endif // GRPC_PLATFORM_SUPPORTS_POSIX_POLLING
638
633
  }
639
634
 
640
635
  } // namespace experimental
@@ -196,6 +196,7 @@ class PosixEventEngine final : public PosixEventEngineWithFdSupport,
196
196
  const DNSResolver::ResolverOptions& options) override;
197
197
  void Run(Closure* closure) override;
198
198
  void Run(absl::AnyInvocable<void()> closure) override;
199
+ // Caution!! The timer implementation cannot create any fds. See #20418.
199
200
  TaskHandle RunAfter(Duration when, Closure* closure) override;
200
201
  TaskHandle RunAfter(Duration when,
201
202
  absl::AnyInvocable<void()> closure) override;
@@ -23,7 +23,9 @@
23
23
  #include <sys/socket.h> // IWYU pragma: keep
24
24
  #include <unistd.h> // IWYU pragma: keep
25
25
 
26
+ #include <atomic>
26
27
  #include <string>
28
+ #include <tuple>
27
29
  #include <utility>
28
30
 
29
31
  #include "absl/functional/any_invocable.h"
@@ -41,6 +43,7 @@
41
43
  #include "src/core/lib/event_engine/posix_engine/tcp_socket_utils.h"
42
44
  #include "src/core/lib/event_engine/tcp_socket_utils.h"
43
45
  #include "src/core/lib/gprpp/status_helper.h"
46
+ #include "src/core/lib/gprpp/time.h"
44
47
  #include "src/core/lib/iomgr/socket_mutator.h"
45
48
 
46
49
  namespace grpc_event_engine {
@@ -136,6 +139,32 @@ void PosixEngineListenerImpl::AsyncConnectionAcceptor::NotifyOnAccept(
136
139
  switch (errno) {
137
140
  case EINTR:
138
141
  continue;
142
+ case EMFILE:
143
+ // When the process runs out of fds, accept4() returns EMFILE. When
144
+ // this happens, the connection is left in the accept queue until
145
+ // either a read event triggers the on_read callback, or time has
146
+ // passed and the accept should be re-tried regardless. This callback
147
+ // is not cancelled, so a spurious wakeup may occur even when there's
148
+ // nothing to accept. This is not a performant code path, but if an fd
149
+ // limit has been reached, the system is likely in an unhappy state
150
+ // regardless.
151
+ GRPC_LOG_EVERY_N_SEC(1, GPR_ERROR, "%s",
152
+ "File descriptor limit reached. Retrying.");
153
+ handle_->NotifyOnRead(notify_on_accept_);
154
+ // Do not schedule another timer if one is already armed.
155
+ if (retry_timer_armed_.exchange(true)) return;
156
+ // Hold a ref while the retry timer is waiting, to prevent listener
157
+ // destruction and the races that would ensue.
158
+ Ref();
159
+ std::ignore =
160
+ engine_->RunAfter(grpc_core::Duration::Seconds(1), [this]() {
161
+ retry_timer_armed_.store(false);
162
+ if (!handle_->IsHandleShutdown()) {
163
+ handle_->SetReadable();
164
+ }
165
+ Unref();
166
+ });
167
+ return;
139
168
  case EAGAIN:
140
169
  case ECONNABORTED:
141
170
  handle_->NotifyOnRead(notify_on_accept_);
@@ -121,6 +121,9 @@ class PosixEngineListenerImpl
121
121
  ListenerSocketsContainer::ListenerSocket socket_;
122
122
  EventHandle* handle_;
123
123
  PosixEngineClosure* notify_on_accept_;
124
+ // Tracks the status of a backup timer to retry accept4 calls after file
125
+ // descriptor exhaustion.
126
+ std::atomic<bool> retry_timer_armed_{false};
124
127
  };
125
128
  class ListenerAsyncAcceptors : public ListenerSocketsContainer {
126
129
  public: