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
@@ -219,10 +219,10 @@ RbacConfig::RbacPolicy::Rules::Policy::CidrRange::JsonLoader(const JsonArgs&) {
219
219
  void RbacConfig::RbacPolicy::Rules::Policy::CidrRange::JsonPostLoad(
220
220
  const Json& json, const JsonArgs& args, ValidationErrors* errors) {
221
221
  auto address_prefix = LoadJsonObjectField<std::string>(
222
- json.object_value(), args, "addressPrefix", errors);
223
- auto prefix_len = LoadJsonObjectField<uint32_t>(json.object_value(), args,
224
- "prefixLen", errors,
225
- /*required=*/false);
222
+ json.object(), args, "addressPrefix", errors);
223
+ auto prefix_len =
224
+ LoadJsonObjectField<uint32_t>(json.object(), args, "prefixLen", errors,
225
+ /*required=*/false);
226
226
  cidr_range =
227
227
  Rbac::CidrRange(address_prefix.value_or(""), prefix_len.value_or(0));
228
228
  }
@@ -269,13 +269,13 @@ RbacConfig::RbacPolicy::Rules::Policy::HeaderMatch::JsonLoader(
269
269
  void RbacConfig::RbacPolicy::Rules::Policy::HeaderMatch::JsonPostLoad(
270
270
  const Json& json, const JsonArgs& args, ValidationErrors* errors) {
271
271
  const size_t original_error_size = errors->size();
272
- std::string name = LoadJsonObjectField<std::string>(json.object_value(), args,
273
- "name", errors)
274
- .value_or("");
275
- bool invert_match = LoadJsonObjectField<bool>(json.object_value(), args,
276
- "invertMatch", errors,
277
- /*required=*/false)
278
- .value_or(false);
272
+ std::string name =
273
+ LoadJsonObjectField<std::string>(json.object(), args, "name", errors)
274
+ .value_or("");
275
+ bool invert_match =
276
+ LoadJsonObjectField<bool>(json.object(), args, "invertMatch", errors,
277
+ /*required=*/false)
278
+ .value_or(false);
279
279
  auto set_header_matcher = [&](absl::StatusOr<HeaderMatcher> header_matcher) {
280
280
  if (header_matcher.ok()) {
281
281
  matcher = *header_matcher;
@@ -285,7 +285,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::HeaderMatch::JsonPostLoad(
285
285
  };
286
286
  auto check_match = [&](absl::string_view field_name,
287
287
  HeaderMatcher::Type type) {
288
- auto match = LoadJsonObjectField<std::string>(json.object_value(), args,
288
+ auto match = LoadJsonObjectField<std::string>(json.object(), args,
289
289
  field_name, errors,
290
290
  /*required=*/false);
291
291
  if (match.has_value()) {
@@ -301,9 +301,9 @@ void RbacConfig::RbacPolicy::Rules::Policy::HeaderMatch::JsonPostLoad(
301
301
  check_match("containsMatch", HeaderMatcher::Type::kContains)) {
302
302
  return;
303
303
  }
304
- auto present_match = LoadJsonObjectField<bool>(json.object_value(), args,
305
- "presentMatch", errors,
306
- /*required=*/false);
304
+ auto present_match =
305
+ LoadJsonObjectField<bool>(json.object(), args, "presentMatch", errors,
306
+ /*required=*/false);
307
307
  if (present_match.has_value()) {
308
308
  set_header_matcher(
309
309
  HeaderMatcher::Create(name, HeaderMatcher::Type::kPresent, "", 0, 0,
@@ -311,7 +311,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::HeaderMatch::JsonPostLoad(
311
311
  return;
312
312
  }
313
313
  auto regex_match = LoadJsonObjectField<SafeRegexMatch>(
314
- json.object_value(), args, "safeRegexMatch", errors,
314
+ json.object(), args, "safeRegexMatch", errors,
315
315
  /*required=*/false);
316
316
  if (regex_match.has_value()) {
317
317
  set_header_matcher(
@@ -319,9 +319,9 @@ void RbacConfig::RbacPolicy::Rules::Policy::HeaderMatch::JsonPostLoad(
319
319
  regex_match->regex, 0, 0, false, invert_match));
320
320
  return;
321
321
  }
322
- auto range_match = LoadJsonObjectField<RangeMatch>(json.object_value(), args,
323
- "rangeMatch", errors,
324
- /*required=*/false);
322
+ auto range_match =
323
+ LoadJsonObjectField<RangeMatch>(json.object(), args, "rangeMatch", errors,
324
+ /*required=*/false);
325
325
  if (range_match.has_value()) {
326
326
  set_header_matcher(HeaderMatcher::Create(name, HeaderMatcher::Type::kRange,
327
327
  "", range_match->start,
@@ -349,7 +349,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::StringMatch::JsonPostLoad(
349
349
  const Json& json, const JsonArgs& args, ValidationErrors* errors) {
350
350
  const size_t original_error_size = errors->size();
351
351
  bool ignore_case =
352
- LoadJsonObjectField<bool>(json.object_value(), args, "ignoreCase", errors,
352
+ LoadJsonObjectField<bool>(json.object(), args, "ignoreCase", errors,
353
353
  /*required=*/false)
354
354
  .value_or(false);
355
355
  auto set_string_matcher = [&](absl::StatusOr<StringMatcher> string_matcher) {
@@ -361,7 +361,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::StringMatch::JsonPostLoad(
361
361
  };
362
362
  auto check_match = [&](absl::string_view field_name,
363
363
  StringMatcher::Type type) {
364
- auto match = LoadJsonObjectField<std::string>(json.object_value(), args,
364
+ auto match = LoadJsonObjectField<std::string>(json.object(), args,
365
365
  field_name, errors,
366
366
  /*required=*/false);
367
367
  if (match.has_value()) {
@@ -376,9 +376,9 @@ void RbacConfig::RbacPolicy::Rules::Policy::StringMatch::JsonPostLoad(
376
376
  check_match("contains", StringMatcher::Type::kContains)) {
377
377
  return;
378
378
  }
379
- auto regex_match = LoadJsonObjectField<SafeRegexMatch>(
380
- json.object_value(), args, "safeRegex", errors,
381
- /*required=*/false);
379
+ auto regex_match = LoadJsonObjectField<SafeRegexMatch>(json.object(), args,
380
+ "safeRegex", errors,
381
+ /*required=*/false);
382
382
  if (regex_match.has_value()) {
383
383
  set_string_matcher(StringMatcher::Create(StringMatcher::Type::kSafeRegex,
384
384
  regex_match->regex, ignore_case));
@@ -450,32 +450,32 @@ RbacConfig::RbacPolicy::Rules::Policy::Permission::JsonLoader(const JsonArgs&) {
450
450
  void RbacConfig::RbacPolicy::Rules::Policy::Permission::JsonPostLoad(
451
451
  const Json& json, const JsonArgs& args, ValidationErrors* errors) {
452
452
  const size_t original_error_size = errors->size();
453
- auto any = LoadJsonObjectField<bool>(json.object_value(), args, "any", errors,
453
+ auto any = LoadJsonObjectField<bool>(json.object(), args, "any", errors,
454
454
  /*required=*/false);
455
455
  if (any.has_value()) {
456
456
  permission = std::make_unique<Rbac::Permission>(
457
457
  Rbac::Permission::MakeAnyPermission());
458
458
  return;
459
459
  }
460
- auto header = LoadJsonObjectField<HeaderMatch>(json.object_value(), args,
461
- "header", errors,
462
- /*required=*/false);
460
+ auto header =
461
+ LoadJsonObjectField<HeaderMatch>(json.object(), args, "header", errors,
462
+ /*required=*/false);
463
463
  if (header.has_value()) {
464
464
  permission = std::make_unique<Rbac::Permission>(
465
465
  Rbac::Permission::MakeHeaderPermission(std::move(header->matcher)));
466
466
  return;
467
467
  }
468
- auto url_path = LoadJsonObjectField<PathMatch>(json.object_value(), args,
469
- "urlPath", errors,
470
- /*required=*/false);
468
+ auto url_path =
469
+ LoadJsonObjectField<PathMatch>(json.object(), args, "urlPath", errors,
470
+ /*required=*/false);
471
471
  if (url_path.has_value()) {
472
472
  permission = std::make_unique<Rbac::Permission>(
473
473
  Rbac::Permission::MakePathPermission(url_path->path.matcher));
474
474
  return;
475
475
  }
476
- auto destination_ip = LoadJsonObjectField<CidrRange>(
477
- json.object_value(), args, "destinationIp", errors,
478
- /*required=*/false);
476
+ auto destination_ip = LoadJsonObjectField<CidrRange>(json.object(), args,
477
+ "destinationIp", errors,
478
+ /*required=*/false);
479
479
  if (destination_ip.has_value()) {
480
480
  permission = std::make_unique<Rbac::Permission>(
481
481
  Rbac::Permission::MakeDestIpPermission(
@@ -483,23 +483,23 @@ void RbacConfig::RbacPolicy::Rules::Policy::Permission::JsonPostLoad(
483
483
  return;
484
484
  }
485
485
  auto destination_port = LoadJsonObjectField<uint32_t>(
486
- json.object_value(), args, "destinationPort", errors,
486
+ json.object(), args, "destinationPort", errors,
487
487
  /*required=*/false);
488
488
  if (destination_port.has_value()) {
489
489
  permission = std::make_unique<Rbac::Permission>(
490
490
  Rbac::Permission::MakeDestPortPermission(*destination_port));
491
491
  return;
492
492
  }
493
- auto metadata = LoadJsonObjectField<Metadata>(json.object_value(), args,
494
- "metadata", errors,
495
- /*required=*/false);
493
+ auto metadata =
494
+ LoadJsonObjectField<Metadata>(json.object(), args, "metadata", errors,
495
+ /*required=*/false);
496
496
  if (metadata.has_value()) {
497
497
  permission = std::make_unique<Rbac::Permission>(
498
498
  Rbac::Permission::MakeMetadataPermission(metadata->invert));
499
499
  return;
500
500
  }
501
501
  auto requested_server_name = LoadJsonObjectField<StringMatch>(
502
- json.object_value(), args, "requestedServerName", errors,
502
+ json.object(), args, "requestedServerName", errors,
503
503
  /*required=*/false);
504
504
  if (requested_server_name.has_value()) {
505
505
  permission = std::make_unique<Rbac::Permission>(
@@ -507,7 +507,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::Permission::JsonPostLoad(
507
507
  std::move(requested_server_name->matcher)));
508
508
  return;
509
509
  }
510
- auto rules = LoadJsonObjectField<PermissionList>(json.object_value(), args,
510
+ auto rules = LoadJsonObjectField<PermissionList>(json.object(), args,
511
511
  "andRules", errors,
512
512
  /*required=*/false);
513
513
  if (rules.has_value()) {
@@ -516,8 +516,8 @@ void RbacConfig::RbacPolicy::Rules::Policy::Permission::JsonPostLoad(
516
516
  MakeRbacPermissionList(std::move(rules->rules))));
517
517
  return;
518
518
  }
519
- rules = LoadJsonObjectField<PermissionList>(json.object_value(), args,
520
- "orRules", errors,
519
+ rules = LoadJsonObjectField<PermissionList>(json.object(), args, "orRules",
520
+ errors,
521
521
  /*required=*/false);
522
522
  if (rules.has_value()) {
523
523
  permission =
@@ -525,9 +525,9 @@ void RbacConfig::RbacPolicy::Rules::Policy::Permission::JsonPostLoad(
525
525
  MakeRbacPermissionList(std::move(rules->rules))));
526
526
  return;
527
527
  }
528
- auto not_rule = LoadJsonObjectField<Permission>(json.object_value(), args,
529
- "notRule", errors,
530
- /*required=*/false);
528
+ auto not_rule =
529
+ LoadJsonObjectField<Permission>(json.object(), args, "notRule", errors,
530
+ /*required=*/false);
531
531
  if (not_rule.has_value()) {
532
532
  permission = std::make_unique<Rbac::Permission>(
533
533
  Rbac::Permission::MakeNotPermission(std::move(*not_rule->permission)));
@@ -590,7 +590,7 @@ RbacConfig::RbacPolicy::Rules::Policy::Principal::JsonLoader(const JsonArgs&) {
590
590
  void RbacConfig::RbacPolicy::Rules::Policy::Principal::JsonPostLoad(
591
591
  const Json& json, const JsonArgs& args, ValidationErrors* errors) {
592
592
  const size_t original_error_size = errors->size();
593
- auto any = LoadJsonObjectField<bool>(json.object_value(), args, "any", errors,
593
+ auto any = LoadJsonObjectField<bool>(json.object(), args, "any", errors,
594
594
  /*required=*/false);
595
595
  if (any.has_value()) {
596
596
  principal =
@@ -598,7 +598,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::Principal::JsonPostLoad(
598
598
  return;
599
599
  }
600
600
  auto authenticated = LoadJsonObjectField<Authenticated>(
601
- json.object_value(), args, "authenticated", errors,
601
+ json.object(), args, "authenticated", errors,
602
602
  /*required=*/false);
603
603
  if (authenticated.has_value()) {
604
604
  if (authenticated->principal_name.has_value()) {
@@ -612,16 +612,16 @@ void RbacConfig::RbacPolicy::Rules::Policy::Principal::JsonPostLoad(
612
612
  }
613
613
  return;
614
614
  }
615
- auto cidr_range = LoadJsonObjectField<CidrRange>(json.object_value(), args,
616
- "sourceIp", errors,
617
- /*required=*/false);
615
+ auto cidr_range =
616
+ LoadJsonObjectField<CidrRange>(json.object(), args, "sourceIp", errors,
617
+ /*required=*/false);
618
618
  if (cidr_range.has_value()) {
619
619
  principal = std::make_unique<Rbac::Principal>(
620
620
  Rbac::Principal::MakeSourceIpPrincipal(
621
621
  std::move(cidr_range->cidr_range)));
622
622
  return;
623
623
  }
624
- cidr_range = LoadJsonObjectField<CidrRange>(json.object_value(), args,
624
+ cidr_range = LoadJsonObjectField<CidrRange>(json.object(), args,
625
625
  "directRemoteIp", errors,
626
626
  /*required=*/false);
627
627
  if (cidr_range.has_value()) {
@@ -630,50 +630,49 @@ void RbacConfig::RbacPolicy::Rules::Policy::Principal::JsonPostLoad(
630
630
  std::move(cidr_range->cidr_range)));
631
631
  return;
632
632
  }
633
- cidr_range = LoadJsonObjectField<CidrRange>(json.object_value(), args,
634
- "remoteIp", errors,
635
- /*required=*/false);
633
+ cidr_range =
634
+ LoadJsonObjectField<CidrRange>(json.object(), args, "remoteIp", errors,
635
+ /*required=*/false);
636
636
  if (cidr_range.has_value()) {
637
637
  principal = std::make_unique<Rbac::Principal>(
638
638
  Rbac::Principal::MakeRemoteIpPrincipal(
639
639
  std::move(cidr_range->cidr_range)));
640
640
  return;
641
641
  }
642
- auto header = LoadJsonObjectField<HeaderMatch>(json.object_value(), args,
643
- "header", errors,
644
- /*required=*/false);
642
+ auto header =
643
+ LoadJsonObjectField<HeaderMatch>(json.object(), args, "header", errors,
644
+ /*required=*/false);
645
645
  if (header.has_value()) {
646
646
  principal = std::make_unique<Rbac::Principal>(
647
647
  Rbac::Principal::MakeHeaderPrincipal(std::move(header->matcher)));
648
648
  return;
649
649
  }
650
- auto url_path = LoadJsonObjectField<PathMatch>(json.object_value(), args,
651
- "urlPath", errors,
652
- /*required=*/false);
650
+ auto url_path =
651
+ LoadJsonObjectField<PathMatch>(json.object(), args, "urlPath", errors,
652
+ /*required=*/false);
653
653
  if (url_path.has_value()) {
654
654
  principal = std::make_unique<Rbac::Principal>(
655
655
  Rbac::Principal::MakePathPrincipal(std::move(url_path->path.matcher)));
656
656
  return;
657
657
  }
658
- auto metadata = LoadJsonObjectField<Metadata>(json.object_value(), args,
659
- "metadata", errors,
660
- /*required=*/false);
658
+ auto metadata =
659
+ LoadJsonObjectField<Metadata>(json.object(), args, "metadata", errors,
660
+ /*required=*/false);
661
661
  if (metadata.has_value()) {
662
662
  principal = std::make_unique<Rbac::Principal>(
663
663
  Rbac::Principal::MakeMetadataPrincipal(metadata->invert));
664
664
  return;
665
665
  }
666
- auto ids = LoadJsonObjectField<PrincipalList>(json.object_value(), args,
667
- "andIds", errors,
668
- /*required=*/false);
666
+ auto ids =
667
+ LoadJsonObjectField<PrincipalList>(json.object(), args, "andIds", errors,
668
+ /*required=*/false);
669
669
  if (ids.has_value()) {
670
670
  principal =
671
671
  std::make_unique<Rbac::Principal>(Rbac::Principal::MakeAndPrincipal(
672
672
  MakeRbacPrincipalList(std::move(ids->ids))));
673
673
  return;
674
674
  }
675
- ids = LoadJsonObjectField<PrincipalList>(json.object_value(), args, "orIds",
676
- errors,
675
+ ids = LoadJsonObjectField<PrincipalList>(json.object(), args, "orIds", errors,
677
676
  /*required=*/false);
678
677
  if (ids.has_value()) {
679
678
  principal =
@@ -682,7 +681,7 @@ void RbacConfig::RbacPolicy::Rules::Policy::Principal::JsonPostLoad(
682
681
  return;
683
682
  }
684
683
  auto not_rule =
685
- LoadJsonObjectField<Principal>(json.object_value(), args, "notId", errors,
684
+ LoadJsonObjectField<Principal>(json.object(), args, "notId", errors,
686
685
  /*required=*/false);
687
686
  if (not_rule.has_value()) {
688
687
  principal = std::make_unique<Rbac::Principal>(
@@ -29,6 +29,7 @@
29
29
  #include <new>
30
30
  #include <string>
31
31
  #include <utility>
32
+ #include <vector>
32
33
 
33
34
  #include "absl/base/attributes.h"
34
35
  #include "absl/status/status.h"
@@ -47,7 +48,7 @@
47
48
  #include <grpc/support/log.h>
48
49
  #include <grpc/support/time.h>
49
50
 
50
- #include "src/core/ext/transport/chttp2/transport/context_list.h"
51
+ #include "src/core/ext/transport/chttp2/transport/context_list_entry.h"
51
52
  #include "src/core/ext/transport/chttp2/transport/flow_control.h"
52
53
  #include "src/core/ext/transport/chttp2/transport/frame.h"
53
54
  #include "src/core/ext/transport/chttp2/transport/frame_data.h"
@@ -78,7 +79,6 @@
78
79
  #include "src/core/lib/iomgr/exec_ctx.h"
79
80
  #include "src/core/lib/iomgr/iomgr_fwd.h"
80
81
  #include "src/core/lib/iomgr/port.h"
81
- #include "src/core/lib/iomgr/timer.h"
82
82
  #include "src/core/lib/promise/poll.h"
83
83
  #include "src/core/lib/resource_quota/arena.h"
84
84
  #include "src/core/lib/resource_quota/memory_quota.h"
@@ -215,6 +215,9 @@ grpc_core::CallTracerInterface* CallTracerIfEnabled(grpc_chttp2_stream* s) {
215
215
  s->context)[GRPC_CONTEXT_CALL_TRACER_ANNOTATION_INTERFACE]
216
216
  .value);
217
217
  }
218
+
219
+ grpc_core::WriteTimestampsCallback g_write_timestamps_callback = nullptr;
220
+ grpc_core::CopyContextFn g_get_copied_context_fn = nullptr;
218
221
  } // namespace
219
222
 
220
223
  namespace grpc_core {
@@ -241,6 +244,40 @@ void TestOnlyGlobalHttp2TransportDisableTransientFailureStateNotification(
241
244
  test_only_disable_transient_failure_state_notification = disable;
242
245
  }
243
246
 
247
+ void GrpcHttp2SetWriteTimestampsCallback(WriteTimestampsCallback fn) {
248
+ g_write_timestamps_callback = fn;
249
+ }
250
+
251
+ void GrpcHttp2SetCopyContextFn(CopyContextFn fn) {
252
+ g_get_copied_context_fn = fn;
253
+ }
254
+
255
+ WriteTimestampsCallback GrpcHttp2GetWriteTimestampsCallback() {
256
+ return g_write_timestamps_callback;
257
+ }
258
+
259
+ CopyContextFn GrpcHttp2GetCopyContextFn() { return g_get_copied_context_fn; }
260
+
261
+ // For each entry in the passed ContextList, it executes the function set using
262
+ // GrpcHttp2SetWriteTimestampsCallback method with each context in the list
263
+ // and \a ts. It also deletes/frees up the passed ContextList after this
264
+ // operation.
265
+ void ForEachContextListEntryExecute(void* arg, Timestamps* ts,
266
+ grpc_error_handle error) {
267
+ ContextList* context_list = reinterpret_cast<ContextList*>(arg);
268
+ if (!context_list) {
269
+ return;
270
+ }
271
+ for (auto it = context_list->begin(); it != context_list->end(); it++) {
272
+ ContextListEntry& entry = (*it);
273
+ if (ts) {
274
+ ts->byte_offset = static_cast<uint32_t>(entry.ByteOffsetInStream());
275
+ }
276
+ g_write_timestamps_callback(entry.TraceContext(), ts, error);
277
+ }
278
+ delete context_list;
279
+ }
280
+
244
281
  } // namespace grpc_core
245
282
 
246
283
  //
@@ -265,7 +302,9 @@ grpc_chttp2_transport::~grpc_chttp2_transport() {
265
302
  grpc_error_handle error = GRPC_ERROR_CREATE("Transport destroyed");
266
303
  // ContextList::Execute follows semantics of a callback function and does not
267
304
  // take a ref on error
268
- grpc_core::ContextList::Execute(cl, nullptr, error);
305
+ if (cl != nullptr) {
306
+ grpc_core::ForEachContextListEntryExecute(cl, nullptr, error);
307
+ }
269
308
  cl = nullptr;
270
309
 
271
310
  grpc_slice_buffer_destroy(&read_buffer);
@@ -370,6 +409,8 @@ static void read_channel_args(grpc_chttp2_transport* t,
370
409
  .GetObjectRef<grpc_core::channelz::SocketNode::Security>());
371
410
  }
372
411
 
412
+ t->ack_pings = channel_args.GetBool("grpc.http2.ack_pings").value_or(true);
413
+
373
414
  const int soft_limit =
374
415
  channel_args.GetInt(GRPC_ARG_MAX_METADATA_SIZE).value_or(-1);
375
416
  if (soft_limit < 0) {
@@ -444,7 +485,7 @@ static void read_channel_args(grpc_chttp2_transport* t,
444
485
  // `GRPC_ARG_ABSOLUTE_MAX_METADATA_SIZE` is not set.
445
486
  const int soft_limit = channel_args.GetInt(GRPC_ARG_MAX_METADATA_SIZE)
446
487
  .value_or(setting.default_value);
447
- const int value = (soft_limit < (INT_MAX / 1.25))
488
+ const int value = (soft_limit >= 0 && soft_limit < (INT_MAX / 1.25))
448
489
  ? static_cast<int>(soft_limit * 1.25)
449
490
  : soft_limit;
450
491
  if (value > DEFAULT_MAX_HEADER_LIST_SIZE) {
@@ -553,6 +594,7 @@ grpc_chttp2_transport::grpc_chttp2_transport(
553
594
  event_engine(
554
595
  channel_args
555
596
  .GetObjectRef<grpc_event_engine::experimental::EventEngine>()) {
597
+ cl = new grpc_core::ContextList();
556
598
  GPR_ASSERT(strlen(GRPC_CHTTP2_CLIENT_CONNECT_STRING) ==
557
599
  GRPC_CHTTP2_CLIENT_CONNECT_STRLEN);
558
600
  base.vtable = get_vtable();
@@ -984,7 +1026,17 @@ static void write_action_begin_locked(void* gt,
984
1026
  static void write_action(void* gt, grpc_error_handle /*error*/) {
985
1027
  grpc_chttp2_transport* t = static_cast<grpc_chttp2_transport*>(gt);
986
1028
  void* cl = t->cl;
987
- t->cl = nullptr;
1029
+ if (!t->cl->empty()) {
1030
+ // Transfer the ownership of the context list to the endpoint and create and
1031
+ // associate a new context list with the transport.
1032
+ // The old context list is stored in the cl local variable which is passed
1033
+ // to the endpoint. Its upto the endpoint to manage its lifetime.
1034
+ t->cl = new grpc_core::ContextList();
1035
+ } else {
1036
+ // t->cl is Empty. There is nothing to trace in this endpoint_write. set cl
1037
+ // to nullptr.
1038
+ cl = nullptr;
1039
+ }
988
1040
  // Choose max_frame_size as the prefered rx crypto frame size indicated by the
989
1041
  // peer.
990
1042
  int max_frame_size =
@@ -1694,7 +1746,7 @@ namespace {
1694
1746
  // Fire and forget (deletes itself on completion). Does a graceful shutdown by
1695
1747
  // sending a GOAWAY frame with the last stream id set to 2^31-1, sending a ping
1696
1748
  // and waiting for an ack (effective waiting for an RTT) and then sending a
1697
- // final GOAWAY freame with an updated last stream identifier. This helps ensure
1749
+ // final GOAWAY frame with an updated last stream identifier. This helps ensure
1698
1750
  // that a connection can be cleanly shut down without losing requests.
1699
1751
  // In the event, that the client does not respond to the ping for some reason,
1700
1752
  // we add a 20 second deadline, after which we send the second goaway.
@@ -1707,6 +1759,8 @@ class GracefulGoaway : public grpc_core::RefCounted<GracefulGoaway> {
1707
1759
  }
1708
1760
 
1709
1761
  private:
1762
+ using TaskHandle = ::grpc_event_engine::experimental::EventEngine::TaskHandle;
1763
+
1710
1764
  explicit GracefulGoaway(grpc_chttp2_transport* t) : t_(t) {
1711
1765
  t->sent_goaway_state = GRPC_CHTTP2_GRACEFUL_GOAWAY;
1712
1766
  GRPC_CHTTP2_REF_TRANSPORT(t_, "graceful goaway");
@@ -1714,10 +1768,17 @@ class GracefulGoaway : public grpc_core::RefCounted<GracefulGoaway> {
1714
1768
  send_ping_locked(
1715
1769
  t, nullptr, GRPC_CLOSURE_INIT(&on_ping_ack_, OnPingAck, this, nullptr));
1716
1770
  grpc_chttp2_initiate_write(t, GRPC_CHTTP2_INITIATE_WRITE_GOAWAY_SENT);
1717
- Ref().release(); // Ref for the timer
1718
- grpc_timer_init(
1719
- &timer_, grpc_core::Timestamp::Now() + grpc_core::Duration::Seconds(20),
1720
- GRPC_CLOSURE_INIT(&on_timer_, OnTimer, this, nullptr));
1771
+ timer_handle_ = t_->event_engine->RunAfter(
1772
+ grpc_core::Duration::Seconds(20),
1773
+ [self = Ref(DEBUG_LOCATION, "GoawayTimer")]() mutable {
1774
+ grpc_core::ApplicationCallbackExecCtx callback_exec_ctx;
1775
+ grpc_core::ExecCtx exec_ctx;
1776
+ // The ref will be unreffed in the combiner.
1777
+ auto* ptr = self.release();
1778
+ ptr->t_->combiner->Run(
1779
+ GRPC_CLOSURE_INIT(&ptr->on_timer_, OnTimerLocked, ptr, nullptr),
1780
+ absl::OkStatus());
1781
+ });
1721
1782
  }
1722
1783
 
1723
1784
  void MaybeSendFinalGoawayLocked() {
@@ -1757,31 +1818,25 @@ class GracefulGoaway : public grpc_core::RefCounted<GracefulGoaway> {
1757
1818
 
1758
1819
  static void OnPingAckLocked(void* arg, grpc_error_handle /* error */) {
1759
1820
  auto* self = static_cast<GracefulGoaway*>(arg);
1760
- grpc_timer_cancel(&self->timer_);
1821
+ if (self->timer_handle_ != TaskHandle::kInvalid) {
1822
+ self->t_->event_engine->Cancel(
1823
+ std::exchange(self->timer_handle_, TaskHandle::kInvalid));
1824
+ }
1761
1825
  self->MaybeSendFinalGoawayLocked();
1762
1826
  self->Unref();
1763
1827
  }
1764
1828
 
1765
- static void OnTimer(void* arg, grpc_error_handle error) {
1766
- auto* self = static_cast<GracefulGoaway*>(arg);
1767
- if (!error.ok()) {
1768
- self->Unref();
1769
- return;
1770
- }
1771
- self->t_->combiner->Run(
1772
- GRPC_CLOSURE_INIT(&self->on_timer_, OnTimerLocked, self, nullptr),
1773
- absl::OkStatus());
1774
- }
1775
-
1776
1829
  static void OnTimerLocked(void* arg, grpc_error_handle /* error */) {
1777
1830
  auto* self = static_cast<GracefulGoaway*>(arg);
1831
+ // Clearing the handle since the timer has fired and the handle is invalid.
1832
+ self->timer_handle_ = TaskHandle::kInvalid;
1778
1833
  self->MaybeSendFinalGoawayLocked();
1779
1834
  self->Unref();
1780
1835
  }
1781
1836
 
1782
1837
  grpc_chttp2_transport* t_;
1783
1838
  grpc_closure on_ping_ack_;
1784
- grpc_timer timer_;
1839
+ TaskHandle timer_handle_ = TaskHandle::kInvalid;
1785
1840
  grpc_closure on_timer_;
1786
1841
  };
1787
1842
 
@@ -27,8 +27,10 @@
27
27
  #include "src/core/lib/channel/channelz.h"
28
28
  #include "src/core/lib/debug/trace.h"
29
29
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
30
+ #include "src/core/lib/iomgr/buffer_list.h"
30
31
  #include "src/core/lib/iomgr/closure.h"
31
32
  #include "src/core/lib/iomgr/endpoint.h"
33
+ #include "src/core/lib/iomgr/error.h"
32
34
  #include "src/core/lib/transport/transport_fwd.h"
33
35
 
34
36
  extern grpc_core::TraceFlag grpc_keepalive_trace;
@@ -71,6 +73,25 @@ void TestOnlySetGlobalHttp2TransportDestructCallback(
71
73
  // same time that a GOAWAY is received.
72
74
  void TestOnlyGlobalHttp2TransportDisableTransientFailureStateNotification(
73
75
  bool disable);
76
+
77
+ typedef void (*WriteTimestampsCallback)(void*, Timestamps*,
78
+ grpc_error_handle error);
79
+ typedef void* (*CopyContextFn)(void*);
80
+
81
+ void GrpcHttp2SetWriteTimestampsCallback(WriteTimestampsCallback fn);
82
+ void GrpcHttp2SetCopyContextFn(CopyContextFn fn);
83
+
84
+ WriteTimestampsCallback GrpcHttp2GetWriteTimestampsCallback();
85
+ CopyContextFn GrpcHttp2GetCopyContextFn();
86
+
87
+ // Interprets the passed arg as a ContextList type and for each entry in the
88
+ // passed ContextList, it executes the function set using
89
+ // GrpcHttp2SetWriteTimestampsCallback method with each context in the list
90
+ // and \a ts. It also deletes/frees up the passed ContextList after this
91
+ // operation.
92
+ void ForEachContextListEntryExecute(void* arg, Timestamps* ts,
93
+ grpc_error_handle error);
94
+
74
95
  } // namespace grpc_core
75
96
 
76
97
  #endif // GRPC_SRC_CORE_EXT_TRANSPORT_CHTTP2_TRANSPORT_CHTTP2_TRANSPORT_H
@@ -0,0 +1,70 @@
1
+ //
2
+ //
3
+ // Copyright 2018 gRPC authors.
4
+ //
5
+ // Licensed under the Apache License, Version 2.0 (the "License");
6
+ // you may not use this file except in compliance with the License.
7
+ // You may obtain a copy of the License at
8
+ //
9
+ // http://www.apache.org/licenses/LICENSE-2.0
10
+ //
11
+ // Unless required by applicable law or agreed to in writing, software
12
+ // distributed under the License is distributed on an "AS IS" BASIS,
13
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ // See the License for the specific language governing permissions and
15
+ // limitations under the License.
16
+ //
17
+ //
18
+
19
+ #ifndef GRPC_SRC_CORE_EXT_TRANSPORT_CHTTP2_TRANSPORT_CONTEXT_LIST_ENTRY_H
20
+ #define GRPC_SRC_CORE_EXT_TRANSPORT_CHTTP2_TRANSPORT_CONTEXT_LIST_ENTRY_H
21
+
22
+ #include <grpc/support/port_platform.h>
23
+
24
+ #include <stddef.h>
25
+ #include <stdint.h>
26
+
27
+ #include <vector>
28
+
29
+ namespace grpc_core {
30
+
31
+ /// An RPC trace context and associated information. Each RPC/stream is
32
+ /// associated with a unique \a context. A new ContextList entry is created when
33
+ /// a chunk of data stored in an outgoing buffer is going to be
34
+ // sent over the wire. A data chunk being written over the wire is multiplexed
35
+ // with bytes from multiple RPCs. If one such RPC is traced, we store the
36
+ // following information about the traced RPC:
37
+ // - byte_offset_in_stream: Number of bytes belonging to that traced RPC which
38
+ // have been sent so far from the start of the RPC stream.
39
+ // - relative_start_pos_in_chunk: Starting offset of the traced RPC within
40
+ // the current chunk that is being sent.
41
+ // - num_traced_bytes_in_chunk: Number of bytes belonging to the traced RPC
42
+ // within the current chunk.
43
+ class ContextListEntry {
44
+ public:
45
+ ContextListEntry(void* context, int64_t relative_start_pos,
46
+ int64_t num_traced_bytes, size_t byte_offset)
47
+ : trace_context_(context),
48
+ relative_start_pos_in_chunk_(relative_start_pos),
49
+ num_traced_bytes_in_chunk_(num_traced_bytes),
50
+ byte_offset_in_stream_(byte_offset) {}
51
+
52
+ ContextListEntry() = delete;
53
+
54
+ void* TraceContext() { return trace_context_; }
55
+ int64_t RelativeStartPosInChunk() { return relative_start_pos_in_chunk_; }
56
+ int64_t NumTracedBytesInChunk() { return num_traced_bytes_in_chunk_; }
57
+ size_t ByteOffsetInStream() { return byte_offset_in_stream_; }
58
+
59
+ private:
60
+ void* trace_context_;
61
+ int64_t relative_start_pos_in_chunk_;
62
+ int64_t num_traced_bytes_in_chunk_;
63
+ size_t byte_offset_in_stream_;
64
+ };
65
+
66
+ /// A list of RPC Contexts
67
+ typedef std::vector<ContextListEntry> ContextList;
68
+ } // namespace grpc_core
69
+
70
+ #endif // GRPC_SRC_CORE_EXT_TRANSPORT_CHTTP2_TRANSPORT_CONTEXT_LIST_ENTRY_H
@@ -35,8 +35,6 @@
35
35
  #include "src/core/ext/transport/chttp2/transport/stream_map.h"
36
36
  #include "src/core/lib/gprpp/time.h"
37
37
 
38
- static bool g_disable_ping_ack = false;
39
-
40
38
  grpc_slice grpc_chttp2_ping_create(uint8_t ack, uint64_t opaque_8bytes) {
41
39
  grpc_slice slice = GRPC_SLICE_MALLOC(9 + 8);
42
40
  uint8_t* p = GRPC_SLICE_START_PTR(slice);
@@ -116,7 +114,7 @@ grpc_error_handle grpc_chttp2_ping_parser_parse(void* parser,
116
114
 
117
115
  t->ping_recv_state.last_ping_recv_time = now;
118
116
  }
119
- if (!g_disable_ping_ack) {
117
+ if (t->ack_pings) {
120
118
  if (t->ping_ack_count == t->ping_ack_capacity) {
121
119
  t->ping_ack_capacity =
122
120
  std::max(t->ping_ack_capacity * 3 / 2, size_t{3});
@@ -132,7 +130,3 @@ grpc_error_handle grpc_chttp2_ping_parser_parse(void* parser,
132
130
 
133
131
  return absl::OkStatus();
134
132
  }
135
-
136
- void grpc_set_disable_ping_ack(bool disable_ping_ack) {
137
- g_disable_ping_ack = disable_ping_ack;
138
- }