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
@@ -24,7 +24,6 @@
24
24
  #include <stdlib.h>
25
25
 
26
26
  #include <algorithm>
27
- #include <initializer_list>
28
27
  #include <string>
29
28
  #include <utility>
30
29
 
@@ -32,21 +31,22 @@
32
31
  #include "absl/status/status.h"
33
32
  #include "absl/strings/match.h"
34
33
  #include "absl/strings/str_cat.h"
35
- #include "absl/strings/str_format.h"
36
34
  #include "absl/strings/string_view.h"
37
35
  #include "absl/types/optional.h"
38
36
  #include "absl/types/span.h"
39
37
  #include "absl/types/variant.h"
40
38
 
39
+ #include <grpc/slice.h>
41
40
  #include <grpc/support/log.h>
42
41
 
43
42
  #include "src/core/ext/transport/chttp2/transport/decode_huff.h"
44
43
  #include "src/core/ext/transport/chttp2/transport/hpack_constants.h"
44
+ #include "src/core/ext/transport/chttp2/transport/hpack_parse_result.h"
45
+ #include "src/core/ext/transport/chttp2/transport/hpack_parser_table.h"
45
46
  #include "src/core/lib/debug/stats.h"
46
47
  #include "src/core/lib/debug/stats_data.h"
47
48
  #include "src/core/lib/debug/trace.h"
48
- #include "src/core/lib/gprpp/crash.h"
49
- #include "src/core/lib/gprpp/status_helper.h"
49
+ #include "src/core/lib/gprpp/match.h"
50
50
  #include "src/core/lib/slice/slice.h"
51
51
  #include "src/core/lib/slice/slice_refcount.h"
52
52
  #include "src/core/lib/surface/validate_metadata.h"
@@ -82,39 +82,6 @@ struct Base64InverseTable {
82
82
 
83
83
  constexpr Base64InverseTable kBase64InverseTable;
84
84
 
85
- absl::Status EnsureStreamError(absl::Status error) {
86
- if (error.ok()) return error;
87
- return grpc_error_set_int(std::move(error), StatusIntProperty::kStreamId, 0);
88
- }
89
-
90
- bool IsStreamError(const absl::Status& status) {
91
- intptr_t stream_id;
92
- return grpc_error_get_int(status, StatusIntProperty::kStreamId, &stream_id);
93
- }
94
-
95
- class MetadataSizeLimitExceededEncoder {
96
- public:
97
- explicit MetadataSizeLimitExceededEncoder(std::string& summary)
98
- : summary_(summary) {}
99
-
100
- void Encode(const Slice& key, const Slice& value) {
101
- AddToSummary(key.as_string_view(), value.size());
102
- }
103
-
104
- template <typename Key, typename Value>
105
- void Encode(Key, const Value& value) {
106
- AddToSummary(Key::key(), EncodedSizeOfKey(Key(), value));
107
- }
108
-
109
- private:
110
- void AddToSummary(absl::string_view key,
111
- size_t value_length) GPR_ATTRIBUTE_NOINLINE {
112
- absl::StrAppend(&summary_, " ", key, ":",
113
- hpack_constants::SizeForEntry(key.size(), value_length),
114
- "B");
115
- }
116
- std::string& summary_;
117
- };
118
85
  } // namespace
119
86
 
120
87
  // Input tracks the current byte through the input data and provides it
@@ -122,11 +89,12 @@ class MetadataSizeLimitExceededEncoder {
122
89
  class HPackParser::Input {
123
90
  public:
124
91
  Input(grpc_slice_refcount* current_slice_refcount, const uint8_t* begin,
125
- const uint8_t* end)
92
+ const uint8_t* end, HpackParseResult& error)
126
93
  : current_slice_refcount_(current_slice_refcount),
127
94
  begin_(begin),
128
95
  end_(end),
129
- frontier_(begin) {}
96
+ frontier_(begin),
97
+ error_(error) {}
130
98
 
131
99
  // If input is backed by a slice, retrieve its refcount. If not, return
132
100
  // nullptr.
@@ -156,7 +124,7 @@ class HPackParser::Input {
156
124
  // of stream
157
125
  absl::optional<uint8_t> Next() {
158
126
  if (end_of_stream()) {
159
- UnexpectedEOF();
127
+ UnexpectedEOF(/*min_progress_size=*/1);
160
128
  return absl::optional<uint8_t>();
161
129
  }
162
130
  return *begin_++;
@@ -202,9 +170,16 @@ class HPackParser::Input {
202
170
 
203
171
  // Spec weirdness: we can add an infinite stream of 0x80 at the end of a
204
172
  // varint and still end up with a correctly encoded varint.
173
+ // We allow up to 16 just for kicks, but any more and we'll assume the
174
+ // sender is being malicious.
175
+ int num_redundant_0x80 = 0;
205
176
  do {
206
177
  cur = Next();
207
178
  if (!cur.has_value()) return {};
179
+ ++num_redundant_0x80;
180
+ if (num_redundant_0x80 == 16) {
181
+ return ParseVarintMaliciousEncoding();
182
+ }
208
183
  } while (*cur == 0x80);
209
184
 
210
185
  // BUT... the last byte needs to be 0x00 or we'll overflow dramatically!
@@ -212,14 +187,6 @@ class HPackParser::Input {
212
187
  return ParseVarintOutOfRange(value, *cur);
213
188
  }
214
189
 
215
- // Prefix for a string
216
- struct StringPrefix {
217
- // Number of bytes in input for string
218
- uint32_t length;
219
- // Is it huffman compressed
220
- bool huff;
221
- };
222
-
223
190
  // Parse a string prefix
224
191
  absl::optional<StringPrefix> ParseStringPrefix() {
225
192
  auto cur = Next();
@@ -243,17 +210,13 @@ class HPackParser::Input {
243
210
  return StringPrefix{strlen, huff};
244
211
  }
245
212
 
246
- // Check if we saw an EOF.. must be verified before looking at TakeError
213
+ // Check if we saw an EOF
247
214
  bool eof_error() const {
248
- return eof_error_ || (!error_.ok() && !IsStreamError(error_));
215
+ return min_progress_size_ != 0 || error_.connection_error();
249
216
  }
250
217
 
251
- // Extract the parse error, leaving the current error as NONE.
252
- grpc_error_handle TakeError() {
253
- grpc_error_handle out = error_;
254
- error_ = absl::OkStatus();
255
- return out;
256
- }
218
+ // Minimum number of bytes to unstuck the current parse
219
+ size_t min_progress_size() const { return min_progress_size_; }
257
220
 
258
221
  bool has_error() const { return !error_.ok(); }
259
222
 
@@ -261,31 +224,55 @@ class HPackParser::Input {
261
224
  // chttp2 does not close the connection.
262
225
  // Intended for errors that are specific to a stream and recoverable.
263
226
  // Callers should ensure that any hpack table updates happen.
264
- GPR_ATTRIBUTE_NOINLINE void SetErrorAndContinueParsing(
265
- grpc_error_handle error) {
266
- GPR_ASSERT(!error.ok());
267
- // StreamId is used as a signal to skip this stream but keep the connection
268
- // alive
269
- SetError(EnsureStreamError(std::move(error)));
227
+ void SetErrorAndContinueParsing(HpackParseResult error) {
228
+ GPR_DEBUG_ASSERT(error.stream_error());
229
+ SetError(std::move(error));
270
230
  }
271
231
 
272
232
  // Set the current error, and skip past remaining bytes.
273
233
  // Intended for unrecoverable errors, with the expectation that they will
274
234
  // close the connection on return to chttp2.
275
- GPR_ATTRIBUTE_NOINLINE void SetErrorAndStopParsing(grpc_error_handle error) {
276
- GPR_ASSERT(!error.ok());
235
+ void SetErrorAndStopParsing(HpackParseResult error) {
236
+ GPR_DEBUG_ASSERT(error.connection_error());
277
237
  SetError(std::move(error));
278
238
  begin_ = end_;
279
239
  }
280
240
 
281
- // Set the error to an unexpected eof
282
- void UnexpectedEOF() {
283
- if (!error_.ok() && !IsStreamError(error_)) return;
284
- eof_error_ = true;
241
+ // Set the error to an unexpected eof.
242
+ // min_progress_size: how many bytes beyond the current frontier do we need to
243
+ // read prior to being able to get further in this parse.
244
+ void UnexpectedEOF(size_t min_progress_size) {
245
+ GPR_ASSERT(min_progress_size > 0);
246
+ if (min_progress_size_ != 0 || error_.connection_error()) {
247
+ GPR_DEBUG_ASSERT(eof_error());
248
+ return;
249
+ }
250
+ // Set min progress size, taking into account bytes parsed already but not
251
+ // consumed.
252
+ min_progress_size_ = min_progress_size + (begin_ - frontier_);
253
+ GPR_DEBUG_ASSERT(eof_error());
285
254
  }
286
255
 
287
256
  // Update the frontier - signifies we've successfully parsed another element
288
- void UpdateFrontier() { frontier_ = begin_; }
257
+ void UpdateFrontier() {
258
+ GPR_DEBUG_ASSERT(skip_bytes_ == 0);
259
+ frontier_ = begin_;
260
+ }
261
+
262
+ void UpdateFrontierAndSkipBytes(size_t skip_bytes) {
263
+ UpdateFrontier();
264
+ size_t remaining = end_ - begin_;
265
+ if (skip_bytes >= remaining) {
266
+ // If we have more bytes to skip than we have remaining in this buffer
267
+ // then we skip over what's there and stash that we need to skip some
268
+ // more.
269
+ skip_bytes_ = skip_bytes - remaining;
270
+ frontier_ = end_;
271
+ } else {
272
+ // Otherwise we zoom through some bytes and continue parsing.
273
+ frontier_ += skip_bytes_;
274
+ }
275
+ }
289
276
 
290
277
  // Get the frontier - for buffering should we fail due to eof
291
278
  const uint8_t* frontier() const { return frontier_; }
@@ -294,19 +281,23 @@ class HPackParser::Input {
294
281
  // Helper to set the error to out of range for ParseVarint
295
282
  absl::optional<uint32_t> ParseVarintOutOfRange(uint32_t value,
296
283
  uint8_t last_byte) {
297
- SetErrorAndStopParsing(absl::InternalError(absl::StrFormat(
298
- "integer overflow in hpack integer decoding: have 0x%08x, "
299
- "got byte 0x%02x on byte 5",
300
- value, last_byte)));
284
+ SetErrorAndStopParsing(
285
+ HpackParseResult::VarintOutOfRangeError(value, last_byte));
286
+ return absl::optional<uint32_t>();
287
+ }
288
+
289
+ // Helper to set the error in the case of a malicious encoding
290
+ absl::optional<uint32_t> ParseVarintMaliciousEncoding() {
291
+ SetErrorAndStopParsing(HpackParseResult::MaliciousVarintEncodingError());
301
292
  return absl::optional<uint32_t>();
302
293
  }
303
294
 
304
295
  // If no error is set, set it to the given error (i.e. first error wins)
305
296
  // Do not use this directly, instead use SetErrorAndContinueParsing or
306
297
  // SetErrorAndStopParsing.
307
- void SetError(grpc_error_handle error) {
308
- if (!error_.ok() || eof_error_) {
309
- if (!IsStreamError(error) && IsStreamError(error_)) {
298
+ void SetError(HpackParseResult error) {
299
+ if (!error_.ok() || min_progress_size_ > 0) {
300
+ if (error.connection_error() && !error_.connection_error()) {
310
301
  error_ = std::move(error); // connection errors dominate
311
302
  }
312
303
  return;
@@ -323,211 +314,156 @@ class HPackParser::Input {
323
314
  // Frontier denotes the first byte past successfully processed input
324
315
  const uint8_t* frontier_;
325
316
  // Current error
326
- grpc_error_handle error_;
327
- // If the error was EOF, we flag it here..
328
- bool eof_error_ = false;
317
+ HpackParseResult& error_;
318
+ // If the error was EOF, we flag it here by noting how many more bytes would
319
+ // be needed to make progress
320
+ size_t min_progress_size_ = 0;
321
+ // Number of bytes that should be skipped before parsing resumes.
322
+ // (We've failed parsing a request for whatever reason, but we're still
323
+ // continuing the connection so we need to see future opcodes after this bit).
324
+ size_t skip_bytes_ = 0;
329
325
  };
330
326
 
331
- // Helper to parse a string and turn it into a slice with appropriate memory
332
- // management characteristics
333
- class HPackParser::String {
334
- public:
335
- // ParseResult carries both a ParseStatus and the parsed string
336
- struct ParseResult;
337
- // Result of parsing a string
338
- enum class ParseStatus {
339
- // Parsed OK
340
- kOk,
341
- // Parse reached end of the current frame
342
- kEof,
343
- // Parse failed due to a huffman decode error
344
- kParseHuffFailed,
345
- // Parse failed due to a base64 decode error
346
- kUnbase64Failed,
347
- };
348
-
349
- String() : value_(absl::Span<const uint8_t>()) {}
350
- String(const String&) = delete;
351
- String& operator=(const String&) = delete;
352
- String(String&& other) noexcept : value_(std::move(other.value_)) {
353
- other.value_ = absl::Span<const uint8_t>();
354
- }
355
- String& operator=(String&& other) noexcept {
356
- value_ = std::move(other.value_);
357
- other.value_ = absl::Span<const uint8_t>();
358
- return *this;
327
+ absl::string_view HPackParser::String::string_view() const {
328
+ if (auto* p = absl::get_if<Slice>(&value_)) {
329
+ return p->as_string_view();
330
+ } else if (auto* p = absl::get_if<absl::Span<const uint8_t>>(&value_)) {
331
+ return absl::string_view(reinterpret_cast<const char*>(p->data()),
332
+ p->size());
333
+ } else if (auto* p = absl::get_if<std::vector<uint8_t>>(&value_)) {
334
+ return absl::string_view(reinterpret_cast<const char*>(p->data()),
335
+ p->size());
359
336
  }
337
+ GPR_UNREACHABLE_CODE(return absl::string_view());
338
+ }
360
339
 
361
- // Take the value and leave this empty
362
- Slice Take();
363
-
364
- // Return a reference to the value as a string view
365
- absl::string_view string_view() const {
366
- if (auto* p = absl::get_if<Slice>(&value_)) {
367
- return p->as_string_view();
368
- } else if (auto* p = absl::get_if<absl::Span<const uint8_t>>(&value_)) {
369
- return absl::string_view(reinterpret_cast<const char*>(p->data()),
370
- p->size());
371
- } else if (auto* p = absl::get_if<std::vector<uint8_t>>(&value_)) {
372
- return absl::string_view(reinterpret_cast<const char*>(p->data()),
373
- p->size());
374
- }
375
- GPR_UNREACHABLE_CODE(return absl::string_view());
340
+ template <typename Out>
341
+ HpackParseStatus HPackParser::String::ParseHuff(Input* input, uint32_t length,
342
+ Out output) {
343
+ // If there's insufficient bytes remaining, return now.
344
+ if (input->remaining() < length) {
345
+ input->UnexpectedEOF(/*min_progress_size=*/length);
346
+ return HpackParseStatus::kEof;
376
347
  }
348
+ // Grab the byte range, and iterate through it.
349
+ const uint8_t* p = input->cur_ptr();
350
+ input->Advance(length);
351
+ return HuffDecoder<Out>(output, p, p + length).Run()
352
+ ? HpackParseStatus::kOk
353
+ : HpackParseStatus::kParseHuffFailed;
354
+ }
377
355
 
378
- // Parse a non-binary string
379
- static ParseResult Parse(Input* input);
356
+ struct HPackParser::String::StringResult {
357
+ StringResult() = delete;
358
+ StringResult(HpackParseStatus status, size_t wire_size, String value)
359
+ : status(status), wire_size(wire_size), value(std::move(value)) {}
360
+ HpackParseStatus status;
361
+ size_t wire_size;
362
+ String value;
363
+ };
380
364
 
381
- // Parse a binary string
382
- static ParseResult ParseBinary(Input* input);
365
+ HPackParser::String::StringResult HPackParser::String::ParseUncompressed(
366
+ Input* input, uint32_t length, uint32_t wire_size) {
367
+ // Check there's enough bytes
368
+ if (input->remaining() < length) {
369
+ input->UnexpectedEOF(/*min_progress_size=*/length);
370
+ GPR_DEBUG_ASSERT(input->eof_error());
371
+ return StringResult{HpackParseStatus::kEof, wire_size, String{}};
372
+ }
373
+ auto* refcount = input->slice_refcount();
374
+ auto* p = input->cur_ptr();
375
+ input->Advance(length);
376
+ if (refcount != nullptr) {
377
+ return StringResult{HpackParseStatus::kOk, wire_size,
378
+ String(refcount, p, p + length)};
379
+ } else {
380
+ return StringResult{HpackParseStatus::kOk, wire_size,
381
+ String(absl::Span<const uint8_t>(p, length))};
382
+ }
383
+ }
383
384
 
384
- private:
385
- void AppendBytes(const uint8_t* data, size_t length);
386
- explicit String(std::vector<uint8_t> v) : value_(std::move(v)) {}
387
- explicit String(absl::Span<const uint8_t> v) : value_(v) {}
388
- String(grpc_slice_refcount* r, const uint8_t* begin, const uint8_t* end)
389
- : value_(Slice::FromRefcountAndBytes(r, begin, end)) {}
390
-
391
- // Parse some huffman encoded bytes, using output(uint8_t b) to emit each
392
- // decoded byte.
393
- template <typename Out>
394
- static ParseStatus ParseHuff(Input* input, uint32_t length, Out output) {
395
- // If there's insufficient bytes remaining, return now.
396
- if (input->remaining() < length) {
397
- input->UnexpectedEOF();
398
- GPR_DEBUG_ASSERT(input->eof_error());
399
- return ParseStatus::kEof;
400
- }
401
- // Grab the byte range, and iterate through it.
402
- const uint8_t* p = input->cur_ptr();
403
- input->Advance(length);
404
- return HuffDecoder<Out>(output, p, p + length).Run()
405
- ? ParseStatus::kOk
406
- : ParseStatus::kParseHuffFailed;
385
+ absl::optional<std::vector<uint8_t>> HPackParser::String::Unbase64Loop(
386
+ const uint8_t* cur, const uint8_t* end) {
387
+ while (cur != end && end[-1] == '=') {
388
+ --end;
407
389
  }
408
390
 
409
- // Parse some uncompressed string bytes.
410
- static ParseResult ParseUncompressed(Input* input, uint32_t length,
411
- uint32_t wire_size);
391
+ std::vector<uint8_t> out;
392
+ out.reserve(3 * (end - cur) / 4 + 3);
393
+
394
+ // Decode 4 bytes at a time while we can
395
+ while (end - cur >= 4) {
396
+ uint32_t bits = kBase64InverseTable.table[*cur];
397
+ if (bits > 63) return {};
398
+ uint32_t buffer = bits << 18;
399
+ ++cur;
400
+
401
+ bits = kBase64InverseTable.table[*cur];
402
+ if (bits > 63) return {};
403
+ buffer |= bits << 12;
404
+ ++cur;
405
+
406
+ bits = kBase64InverseTable.table[*cur];
407
+ if (bits > 63) return {};
408
+ buffer |= bits << 6;
409
+ ++cur;
410
+
411
+ bits = kBase64InverseTable.table[*cur];
412
+ if (bits > 63) return {};
413
+ buffer |= bits;
414
+ ++cur;
415
+
416
+ out.insert(out.end(), {static_cast<uint8_t>(buffer >> 16),
417
+ static_cast<uint8_t>(buffer >> 8),
418
+ static_cast<uint8_t>(buffer)});
419
+ }
420
+ // Deal with the last 0, 1, 2, or 3 bytes.
421
+ switch (end - cur) {
422
+ case 0:
423
+ return out;
424
+ case 1:
425
+ return {};
426
+ case 2: {
427
+ uint32_t bits = kBase64InverseTable.table[*cur];
428
+ if (bits > 63) return {};
429
+ uint32_t buffer = bits << 18;
412
430
 
413
- // Turn base64 encoded bytes into not base64 encoded bytes.
414
- static ParseResult Unbase64(String s);
431
+ ++cur;
432
+ bits = kBase64InverseTable.table[*cur];
433
+ if (bits > 63) return {};
434
+ buffer |= bits << 12;
415
435
 
416
- // Main loop for Unbase64
417
- static absl::optional<std::vector<uint8_t>> Unbase64Loop(const uint8_t* cur,
418
- const uint8_t* end) {
419
- while (cur != end && end[-1] == '=') {
420
- --end;
436
+ if (buffer & 0xffff) return {};
437
+ out.push_back(static_cast<uint8_t>(buffer >> 16));
438
+ return out;
421
439
  }
422
-
423
- std::vector<uint8_t> out;
424
- out.reserve(3 * (end - cur) / 4 + 3);
425
-
426
- // Decode 4 bytes at a time while we can
427
- while (end - cur >= 4) {
440
+ case 3: {
428
441
  uint32_t bits = kBase64InverseTable.table[*cur];
429
442
  if (bits > 63) return {};
430
443
  uint32_t buffer = bits << 18;
431
- ++cur;
432
444
 
445
+ ++cur;
433
446
  bits = kBase64InverseTable.table[*cur];
434
447
  if (bits > 63) return {};
435
448
  buffer |= bits << 12;
436
- ++cur;
437
449
 
450
+ ++cur;
438
451
  bits = kBase64InverseTable.table[*cur];
439
452
  if (bits > 63) return {};
440
453
  buffer |= bits << 6;
441
- ++cur;
442
454
 
443
- bits = kBase64InverseTable.table[*cur];
444
- if (bits > 63) return {};
445
- buffer |= bits;
446
455
  ++cur;
447
-
448
- out.insert(out.end(), {static_cast<uint8_t>(buffer >> 16),
449
- static_cast<uint8_t>(buffer >> 8),
450
- static_cast<uint8_t>(buffer)});
456
+ if (buffer & 0xff) return {};
457
+ out.push_back(static_cast<uint8_t>(buffer >> 16));
458
+ out.push_back(static_cast<uint8_t>(buffer >> 8));
459
+ return out;
451
460
  }
452
- // Deal with the last 0, 1, 2, or 3 bytes.
453
- switch (end - cur) {
454
- case 0:
455
- return out;
456
- case 1:
457
- return {};
458
- case 2: {
459
- uint32_t bits = kBase64InverseTable.table[*cur];
460
- if (bits > 63) return {};
461
- uint32_t buffer = bits << 18;
462
-
463
- ++cur;
464
- bits = kBase64InverseTable.table[*cur];
465
- if (bits > 63) return {};
466
- buffer |= bits << 12;
467
-
468
- if (buffer & 0xffff) return {};
469
- out.push_back(static_cast<uint8_t>(buffer >> 16));
470
- return out;
471
- }
472
- case 3: {
473
- uint32_t bits = kBase64InverseTable.table[*cur];
474
- if (bits > 63) return {};
475
- uint32_t buffer = bits << 18;
476
-
477
- ++cur;
478
- bits = kBase64InverseTable.table[*cur];
479
- if (bits > 63) return {};
480
- buffer |= bits << 12;
481
-
482
- ++cur;
483
- bits = kBase64InverseTable.table[*cur];
484
- if (bits > 63) return {};
485
- buffer |= bits << 6;
486
-
487
- ++cur;
488
- if (buffer & 0xff) return {};
489
- out.push_back(static_cast<uint8_t>(buffer >> 16));
490
- out.push_back(static_cast<uint8_t>(buffer >> 8));
491
- return out;
492
- }
493
- }
494
-
495
- GPR_UNREACHABLE_CODE(return out;);
496
461
  }
497
462
 
498
- absl::variant<Slice, absl::Span<const uint8_t>, std::vector<uint8_t>> value_;
499
- };
500
-
501
- struct HPackParser::String::ParseResult {
502
- ParseResult() = delete;
503
- ParseResult(ParseStatus status, size_t wire_size, String value)
504
- : status(status), wire_size(wire_size), value(std::move(value)) {}
505
- ParseStatus status;
506
- size_t wire_size;
507
- String value;
508
- };
509
-
510
- HPackParser::String::ParseResult HPackParser::String::ParseUncompressed(
511
- Input* input, uint32_t length, uint32_t wire_size) {
512
- // Check there's enough bytes
513
- if (input->remaining() < length) {
514
- input->UnexpectedEOF();
515
- GPR_DEBUG_ASSERT(input->eof_error());
516
- return ParseResult{ParseStatus::kEof, wire_size, String{}};
517
- }
518
- auto* refcount = input->slice_refcount();
519
- auto* p = input->cur_ptr();
520
- input->Advance(length);
521
- if (refcount != nullptr) {
522
- return ParseResult{ParseStatus::kOk, wire_size,
523
- String(refcount, p, p + length)};
524
- } else {
525
- return ParseResult{ParseStatus::kOk, wire_size,
526
- String(absl::Span<const uint8_t>(p, length))};
527
- }
463
+ GPR_UNREACHABLE_CODE(return out;);
528
464
  }
529
465
 
530
- HPackParser::String::ParseResult HPackParser::String::Unbase64(String s) {
466
+ HPackParser::String::StringResult HPackParser::String::Unbase64(String s) {
531
467
  absl::optional<std::vector<uint8_t>> result;
532
468
  if (auto* p = absl::get_if<Slice>(&s.value_)) {
533
469
  result = Unbase64Loop(p->begin(), p->end());
@@ -539,46 +475,38 @@ HPackParser::String::ParseResult HPackParser::String::Unbase64(String s) {
539
475
  result = Unbase64Loop(p->data(), p->data() + p->size());
540
476
  }
541
477
  if (!result.has_value()) {
542
- return ParseResult{ParseStatus::kUnbase64Failed, s.string_view().length(),
543
- String{}};
478
+ return StringResult{HpackParseStatus::kUnbase64Failed,
479
+ s.string_view().length(), String{}};
544
480
  }
545
- return ParseResult{ParseStatus::kOk, s.string_view().length(),
546
- String(std::move(*result))};
481
+ return StringResult{HpackParseStatus::kOk, s.string_view().length(),
482
+ String(std::move(*result))};
547
483
  }
548
484
 
549
- HPackParser::String::ParseResult HPackParser::String::Parse(Input* input) {
550
- auto pfx = input->ParseStringPrefix();
551
- if (!pfx.has_value()) {
552
- GPR_DEBUG_ASSERT(input->eof_error());
553
- return ParseResult{ParseStatus::kEof, 0, String{}};
554
- }
555
- if (pfx->huff) {
485
+ HPackParser::String::StringResult HPackParser::String::Parse(Input* input,
486
+ bool is_huff,
487
+ size_t length) {
488
+ if (is_huff) {
556
489
  // Huffman coded
557
490
  std::vector<uint8_t> output;
558
- ParseStatus sts = ParseHuff(input, pfx->length,
559
- [&output](uint8_t c) { output.push_back(c); });
491
+ HpackParseStatus sts =
492
+ ParseHuff(input, length, [&output](uint8_t c) { output.push_back(c); });
560
493
  size_t wire_len = output.size();
561
- return ParseResult{sts, wire_len, String(std::move(output))};
494
+ return StringResult{sts, wire_len, String(std::move(output))};
562
495
  }
563
- return ParseUncompressed(input, pfx->length, pfx->length);
496
+ return ParseUncompressed(input, length, length);
564
497
  }
565
498
 
566
- HPackParser::String::ParseResult HPackParser::String::ParseBinary(
567
- Input* input) {
568
- auto pfx = input->ParseStringPrefix();
569
- if (!pfx.has_value()) {
570
- GPR_DEBUG_ASSERT(input->eof_error());
571
- return ParseResult{ParseStatus::kEof, 0, String{}};
572
- }
573
- if (!pfx->huff) {
574
- if (pfx->length > 0 && input->peek() == 0) {
499
+ HPackParser::String::StringResult HPackParser::String::ParseBinary(
500
+ Input* input, bool is_huff, size_t length) {
501
+ if (!is_huff) {
502
+ if (length > 0 && input->peek() == 0) {
575
503
  // 'true-binary'
576
504
  input->Advance(1);
577
- return ParseUncompressed(input, pfx->length - 1, pfx->length);
505
+ return ParseUncompressed(input, length - 1, length);
578
506
  }
579
507
  // Base64 encoded... pull out the string, then unbase64 it
580
- auto base64 = ParseUncompressed(input, pfx->length, pfx->length);
581
- if (base64.status != ParseStatus::kOk) return base64;
508
+ auto base64 = ParseUncompressed(input, length, length);
509
+ if (base64.status != HpackParseStatus::kOk) return base64;
582
510
  return Unbase64(std::move(base64.value));
583
511
  } else {
584
512
  // Huffman encoded...
@@ -587,36 +515,35 @@ HPackParser::String::ParseResult HPackParser::String::ParseBinary(
587
515
  // and what is it.
588
516
  enum class State { kUnsure, kBinary, kBase64 };
589
517
  State state = State::kUnsure;
590
- auto sts =
591
- ParseHuff(input, pfx->length, [&state, &decompressed](uint8_t c) {
592
- if (state == State::kUnsure) {
593
- // First byte... if it's zero it's binary
594
- if (c == 0) {
595
- // Save the type, and skip the zero
596
- state = State::kBinary;
597
- return;
598
- } else {
599
- // Flag base64, store this value
600
- state = State::kBase64;
601
- }
602
- }
603
- // Non-first byte, or base64 first byte
604
- decompressed.push_back(c);
605
- });
606
- if (sts != ParseStatus::kOk) {
607
- return ParseResult{sts, 0, String{}};
518
+ auto sts = ParseHuff(input, length, [&state, &decompressed](uint8_t c) {
519
+ if (state == State::kUnsure) {
520
+ // First byte... if it's zero it's binary
521
+ if (c == 0) {
522
+ // Save the type, and skip the zero
523
+ state = State::kBinary;
524
+ return;
525
+ } else {
526
+ // Flag base64, store this value
527
+ state = State::kBase64;
528
+ }
529
+ }
530
+ // Non-first byte, or base64 first byte
531
+ decompressed.push_back(c);
532
+ });
533
+ if (sts != HpackParseStatus::kOk) {
534
+ return StringResult{sts, 0, String{}};
608
535
  }
609
536
  switch (state) {
610
537
  case State::kUnsure:
611
538
  // No bytes, empty span
612
- return ParseResult{ParseStatus::kOk, 0,
613
- String(absl::Span<const uint8_t>())};
539
+ return StringResult{HpackParseStatus::kOk, 0,
540
+ String(absl::Span<const uint8_t>())};
614
541
  case State::kBinary:
615
542
  // Binary, we're done
616
543
  {
617
544
  size_t wire_len = decompressed.size();
618
- return ParseResult{ParseStatus::kOk, wire_len,
619
- String(std::move(decompressed))};
545
+ return StringResult{HpackParseStatus::kOk, wire_len,
546
+ String(std::move(decompressed))};
620
547
  }
621
548
  case State::kBase64:
622
549
  // Base64 - unpack it
@@ -629,28 +556,38 @@ HPackParser::String::ParseResult HPackParser::String::ParseBinary(
629
556
  // Parser parses one key/value pair from a byte stream.
630
557
  class HPackParser::Parser {
631
558
  public:
632
- Parser(Input* input, grpc_metadata_batch* metadata_buffer, HPackTable* table,
633
- uint8_t* dynamic_table_updates_allowed, uint32_t* frame_length,
634
- RandomEarlyDetection* metadata_early_detection, LogInfo log_info)
559
+ Parser(Input* input, grpc_metadata_batch*& metadata_buffer,
560
+ InterSliceState& state, LogInfo log_info)
635
561
  : input_(input),
636
562
  metadata_buffer_(metadata_buffer),
637
- table_(table),
638
- dynamic_table_updates_allowed_(dynamic_table_updates_allowed),
639
- frame_length_(frame_length),
640
- metadata_early_detection_(metadata_early_detection),
563
+ state_(state),
641
564
  log_info_(log_info) {}
642
565
 
643
- // Skip any priority bits, or return false on failure
644
- bool SkipPriority() {
645
- if (input_->remaining() < 5) {
646
- input_->UnexpectedEOF();
647
- return false;
566
+ bool Parse() {
567
+ switch (state_.parse_state) {
568
+ case ParseState::kTop:
569
+ return ParseTop();
570
+ case ParseState::kParsingKeyLength:
571
+ return ParseKeyLength();
572
+ case ParseState::kParsingKeyBody:
573
+ return ParseKeyBody();
574
+ case ParseState::kSkippingKeyBody:
575
+ return SkipKeyBody();
576
+ case ParseState::kParsingValueLength:
577
+ return ParseValueLength();
578
+ case ParseState::kParsingValueBody:
579
+ return ParseValueBody();
580
+ case ParseState::kSkippingValueLength:
581
+ return SkipValueLength();
582
+ case ParseState::kSkippingValueBody:
583
+ return SkipValueBody();
648
584
  }
649
- input_->Advance(5);
650
- return true;
585
+ GPR_UNREACHABLE_CODE(return false);
651
586
  }
652
587
 
653
- bool Parse() {
588
+ private:
589
+ bool ParseTop() {
590
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kTop);
654
591
  auto cur = *input_->Next();
655
592
  switch (cur >> 4) {
656
593
  // Literal header not indexed - First byte format: 0000xxxx
@@ -663,11 +600,11 @@ class HPackParser::Parser {
663
600
  case 1:
664
601
  switch (cur & 0xf) {
665
602
  case 0: // literal key
666
- return FinishHeaderOmitFromTable(ParseLiteralKey());
603
+ return StartParseLiteralKey(false);
667
604
  case 0xf: // varint encoded key index
668
- return FinishHeaderOmitFromTable(ParseVarIdxKey(0xf));
605
+ return StartVarIdxKey(0xf, false);
669
606
  default: // inline encoded key index
670
- return FinishHeaderOmitFromTable(ParseIdxKey(cur & 0xf));
607
+ return StartIdxKey(cur & 0xf, false);
671
608
  }
672
609
  // Update max table size.
673
610
  // First byte format: 001xxxxx
@@ -694,20 +631,20 @@ class HPackParser::Parser {
694
631
  case 4:
695
632
  if (cur == 0x40) {
696
633
  // literal key
697
- return FinishHeaderAndAddToTable(ParseLiteralKey());
634
+ return StartParseLiteralKey(true);
698
635
  }
699
636
  ABSL_FALLTHROUGH_INTENDED;
700
637
  case 5:
701
638
  case 6:
702
639
  // inline encoded key index
703
- return FinishHeaderAndAddToTable(ParseIdxKey(cur & 0x3f));
640
+ return StartIdxKey(cur & 0x3f, true);
704
641
  case 7:
705
642
  if (cur == 0x7f) {
706
643
  // varint encoded key index
707
- return FinishHeaderAndAddToTable(ParseVarIdxKey(0x3f));
644
+ return StartVarIdxKey(0x3f, true);
708
645
  } else {
709
646
  // inline encoded key index
710
- return FinishHeaderAndAddToTable(ParseIdxKey(cur & 0x3f));
647
+ return StartIdxKey(cur & 0x3f, true);
711
648
  }
712
649
  // Indexed Header Field Representation
713
650
  // First byte format: 1xxxxxxx
@@ -719,7 +656,7 @@ class HPackParser::Parser {
719
656
  if (cur == 0x80) {
720
657
  // illegal value.
721
658
  input_->SetErrorAndStopParsing(
722
- absl::InternalError("Illegal hpack op code"));
659
+ HpackParseResult::IllegalHpackOpCode());
723
660
  return false;
724
661
  }
725
662
  ABSL_FALLTHROUGH_INTENDED;
@@ -743,7 +680,6 @@ class HPackParser::Parser {
743
680
  GPR_UNREACHABLE_CODE(abort());
744
681
  }
745
682
 
746
- private:
747
683
  void GPR_ATTRIBUTE_NOINLINE LogHeader(const HPackTable::Memento& memento) {
748
684
  const char* type;
749
685
  switch (log_info_.type) {
@@ -757,46 +693,48 @@ class HPackParser::Parser {
757
693
  type = "???";
758
694
  break;
759
695
  }
760
- gpr_log(GPR_DEBUG, "HTTP:%d:%s:%s: %s%s", log_info_.stream_id, type,
761
- log_info_.is_client ? "CLI" : "SVR",
762
- memento.md.DebugString().c_str(),
763
- memento.parse_status.ok()
764
- ? ""
765
- : absl::StrCat(
766
- " (parse error: ", memento.parse_status.ToString(), ")")
767
- .c_str());
696
+ gpr_log(
697
+ GPR_DEBUG, "HTTP:%d:%s:%s: %s%s", log_info_.stream_id, type,
698
+ log_info_.is_client ? "CLI" : "SVR", memento.md.DebugString().c_str(),
699
+ memento.parse_status.ok()
700
+ ? ""
701
+ : absl::StrCat(" (parse error: ",
702
+ memento.parse_status.Materialize().ToString(), ")")
703
+ .c_str());
768
704
  }
769
705
 
770
706
  void EmitHeader(const HPackTable::Memento& md) {
771
707
  // Pass up to the transport
772
- *frame_length_ += md.md.transport_size();
773
- if (!input_->has_error() &&
774
- metadata_early_detection_->MustReject(*frame_length_)) {
775
- // Reject any requests above hard metadata limit.
776
- HandleMetadataHardSizeLimitExceeded(md);
777
- }
708
+ state_.frame_length += md.md.transport_size();
778
709
  if (!md.parse_status.ok()) {
779
710
  // Reject any requests with invalid metadata.
780
- HandleMetadataParseError(md.parse_status);
711
+ input_->SetErrorAndContinueParsing(md.parse_status);
781
712
  }
782
713
  if (GPR_LIKELY(metadata_buffer_ != nullptr)) {
783
714
  metadata_buffer_->Set(md.md);
784
715
  }
716
+ if (state_.metadata_early_detection.MustReject(state_.frame_length)) {
717
+ // Reject any requests above hard metadata limit.
718
+ input_->SetErrorAndContinueParsing(
719
+ HpackParseResult::HardMetadataLimitExceededError(
720
+ std::exchange(metadata_buffer_, nullptr), state_.frame_length,
721
+ state_.metadata_early_detection.hard_limit()));
722
+ }
785
723
  }
786
724
 
787
- bool FinishHeaderAndAddToTable(absl::optional<HPackTable::Memento> md) {
788
- // Allow higher code to just pass in failures ... simplifies things a bit.
789
- if (!md.has_value()) return false;
725
+ bool FinishHeaderAndAddToTable(HPackTable::Memento md) {
790
726
  // Log if desired
791
727
  if (GRPC_TRACE_FLAG_ENABLED(grpc_trace_chttp2_hpack_parser)) {
792
- LogHeader(*md);
728
+ LogHeader(md);
793
729
  }
794
730
  // Emit whilst we own the metadata.
795
- EmitHeader(*md);
731
+ EmitHeader(md);
796
732
  // Add to the hpack table
797
- grpc_error_handle err = table_->Add(std::move(*md));
798
- if (GPR_UNLIKELY(!err.ok())) {
799
- input_->SetErrorAndStopParsing(std::move(err));
733
+ if (GPR_UNLIKELY(!state_.hpack_table.Add(std::move(md)))) {
734
+ input_->SetErrorAndStopParsing(
735
+ HpackParseResult::AddBeforeTableSizeUpdated(
736
+ state_.hpack_table.current_table_bytes(),
737
+ state_.hpack_table.max_bytes()));
800
738
  return false;
801
739
  };
802
740
  return true;
@@ -817,136 +755,269 @@ class HPackParser::Parser {
817
755
  EmitHeader(md);
818
756
  }
819
757
 
820
- // Helper type to build a memento from a key & value, and to consolidate some
821
- // tricky error path code.
822
- class MementoBuilder {
823
- public:
824
- explicit MementoBuilder(Input* input, absl::string_view key_string,
825
- absl::Status status = absl::OkStatus())
826
- : input_(input), key_string_(key_string), status_(std::move(status)) {}
827
-
828
- auto ErrorHandler() {
829
- return [this](absl::string_view error, const Slice&) {
830
- auto message =
831
- absl::StrCat("Error parsing '", key_string_,
832
- "' metadata: error=", error, " key=", key_string_);
833
- gpr_log(GPR_ERROR, "%s", message.c_str());
834
- if (status_.ok()) {
835
- status_ = absl::InternalError(message);
836
- }
837
- };
758
+ // Parse an index encoded key and a string encoded value
759
+ bool StartIdxKey(uint32_t index, bool add_to_table) {
760
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kTop);
761
+ input_->UpdateFrontier();
762
+ const auto* elem = state_.hpack_table.Lookup(index);
763
+ if (GPR_UNLIKELY(elem == nullptr)) {
764
+ InvalidHPackIndexError(index);
765
+ return false;
838
766
  }
767
+ state_.parse_state = ParseState::kParsingValueLength;
768
+ state_.is_binary_header = elem->md.is_binary_header();
769
+ state_.key.emplace<const HPackTable::Memento*>(elem);
770
+ state_.add_to_table = add_to_table;
771
+ return ParseValueLength();
772
+ };
839
773
 
840
- HPackTable::Memento Build(ParsedMetadata<grpc_metadata_batch> memento) {
841
- return HPackTable::Memento{std::move(memento), std::move(status_)};
842
- }
774
+ // Parse a varint index encoded key and a string encoded value
775
+ bool StartVarIdxKey(uint32_t offset, bool add_to_table) {
776
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kTop);
777
+ auto index = input_->ParseVarint(offset);
778
+ if (GPR_UNLIKELY(!index.has_value())) return false;
779
+ return StartIdxKey(*index, add_to_table);
780
+ }
843
781
 
844
- // Handle the result of parsing a value.
845
- // Returns true if parsing should continue, false if it should stop.
846
- // Stores an error on the input if necessary.
847
- bool HandleParseResult(String::ParseStatus status) {
848
- auto continuable = [this](absl::string_view error) {
849
- auto this_error = absl::InternalError(absl::StrCat(
850
- "Error parsing '", key_string_, "' metadata: error=", error));
851
- if (status_.ok()) status_ = this_error;
852
- input_->SetErrorAndContinueParsing(std::move(this_error));
853
- };
854
- switch (status) {
855
- case String::ParseStatus::kOk:
856
- return true;
857
- case String::ParseStatus::kParseHuffFailed:
858
- input_->SetErrorAndStopParsing(
859
- absl::InternalError("Huffman decoding failed"));
860
- return false;
861
- case String::ParseStatus::kUnbase64Failed:
862
- continuable("illegal base64 encoding");
863
- return true;
864
- case String::ParseStatus::kEof:
865
- GPR_DEBUG_ASSERT(input_->eof_error());
866
- return false;
867
- }
868
- GPR_UNREACHABLE_CODE(return false);
869
- }
782
+ bool StartParseLiteralKey(bool add_to_table) {
783
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kTop);
784
+ state_.add_to_table = add_to_table;
785
+ state_.parse_state = ParseState::kParsingKeyLength;
786
+ input_->UpdateFrontier();
787
+ return ParseKeyLength();
788
+ }
870
789
 
871
- private:
872
- Input* input_;
873
- absl::string_view key_string_;
874
- absl::Status status_;
875
- };
790
+ bool ShouldSkipParsingString(uint64_t string_length) const {
791
+ // We skip parsing if the string is longer than the current table size, and
792
+ // if we would have to reject the string due to metadata length limits
793
+ // regardless of what else was in the metadata batch.
794
+ //
795
+ // Why longer than the current table size? - it simplifies the logic at the
796
+ // end of skipping the string (and possibly a second if this is a key).
797
+ // If a key/value pair longer than the current table size is added to the
798
+ // hpack table we're forced to clear the entire table - this is a
799
+ // predictable operation that's easy to encode and doesn't need any state
800
+ // other than "skipping" to be carried forward.
801
+ // If we did not do this, we could end up in a situation where even though
802
+ // the metadata would overflow the current limit, it might not overflow the
803
+ // current hpack table size, and so we could not skip in on the off chance
804
+ // that we'd need to add it to the hpack table *and* reject the batch as a
805
+ // whole.
806
+ // That would be a mess, we're not doing it.
807
+ //
808
+ // These rules will end up having us parse some things that ultimately get
809
+ // rejected, and that's ok: the important thing is to have a bounded maximum
810
+ // so we can't be forced to infinitely buffer - not to have a perfect
811
+ // computation here.
812
+ return string_length > state_.hpack_table.current_table_size() &&
813
+ state_.metadata_early_detection.MustReject(
814
+ string_length + hpack_constants::kEntryOverhead);
815
+ }
816
+
817
+ bool ParseKeyLength() {
818
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kParsingKeyLength);
819
+ auto pfx = input_->ParseStringPrefix();
820
+ if (!pfx.has_value()) return false;
821
+ state_.is_string_huff_compressed = pfx->huff;
822
+ state_.string_length = pfx->length;
823
+ input_->UpdateFrontier();
824
+ if (ShouldSkipParsingString(state_.string_length)) {
825
+ input_->SetErrorAndContinueParsing(
826
+ HpackParseResult::HardMetadataLimitExceededByKeyError(
827
+ state_.string_length,
828
+ state_.metadata_early_detection.hard_limit()));
829
+ metadata_buffer_ = nullptr;
830
+ state_.parse_state = ParseState::kSkippingKeyBody;
831
+ return SkipKeyBody();
832
+ } else {
833
+ state_.parse_state = ParseState::kParsingKeyBody;
834
+ return ParseKeyBody();
835
+ }
836
+ }
876
837
 
877
- // Parse a string encoded key and a string encoded value
878
- absl::optional<HPackTable::Memento> ParseLiteralKey() {
879
- auto key = String::Parse(input_);
838
+ bool ParseKeyBody() {
839
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kParsingKeyBody);
840
+ auto key = String::Parse(input_, state_.is_string_huff_compressed,
841
+ state_.string_length);
880
842
  switch (key.status) {
881
- case String::ParseStatus::kOk:
843
+ case HpackParseStatus::kOk:
882
844
  break;
883
- case String::ParseStatus::kParseHuffFailed:
884
- input_->SetErrorAndStopParsing(
885
- absl::InternalError("Huffman decoding failed"));
886
- return absl::nullopt;
887
- case String::ParseStatus::kUnbase64Failed:
888
- Crash("unreachable");
889
- case String::ParseStatus::kEof:
845
+ case HpackParseStatus::kEof:
890
846
  GPR_DEBUG_ASSERT(input_->eof_error());
891
- return absl::nullopt;
847
+ return false;
848
+ default:
849
+ input_->SetErrorAndStopParsing(
850
+ HpackParseResult::FromStatus(key.status));
851
+ return false;
892
852
  }
893
- auto key_string = key.value.string_view();
894
- auto value = ParseValueString(absl::EndsWith(key_string, "-bin"));
895
- MementoBuilder builder(input_, key_string,
896
- EnsureStreamError(ValidateKey(key_string)));
897
- if (!builder.HandleParseResult(value.status)) return absl::nullopt;
898
- auto value_slice = value.value.Take();
899
- const auto transport_size =
900
- key_string.size() + value.wire_size + hpack_constants::kEntryOverhead;
901
- return builder.Build(
902
- grpc_metadata_batch::Parse(key_string, std::move(value_slice),
903
- transport_size, builder.ErrorHandler()));
853
+ input_->UpdateFrontier();
854
+ state_.parse_state = ParseState::kParsingValueLength;
855
+ state_.is_binary_header = absl::EndsWith(key.value.string_view(), "-bin");
856
+ state_.key.emplace<Slice>(key.value.Take());
857
+ return ParseValueLength();
904
858
  }
905
859
 
906
- absl::Status ValidateKey(absl::string_view key) {
907
- if (key == HttpSchemeMetadata::key() || key == HttpMethodMetadata::key() ||
908
- key == HttpAuthorityMetadata::key() || key == HttpPathMetadata::key() ||
909
- key == HttpStatusMetadata::key()) {
910
- return absl::OkStatus();
860
+ bool SkipStringBody() {
861
+ auto remaining = input_->remaining();
862
+ if (remaining >= state_.string_length) {
863
+ input_->Advance(state_.string_length);
864
+ return true;
865
+ } else {
866
+ input_->Advance(remaining);
867
+ input_->UpdateFrontier();
868
+ state_.string_length -= remaining;
869
+ // The default action of our outer loop is to buffer up to
870
+ // min_progress_size bytes.
871
+ // We know we need to do nothing up to the string length, so it would be
872
+ // legal to pass that here - however that would cause a client selected
873
+ // large buffer size to be accumulated, which would be an attack vector.
874
+ // We could also pass 1 here, and we'd be called to parse potentially
875
+ // every byte, which would give clients a way to consume substantial CPU -
876
+ // again not great.
877
+ // So we pick some tradeoff number - big enough to amortize wakeups, but
878
+ // probably not big enough to cause excessive memory use on the receiver.
879
+ input_->UnexpectedEOF(
880
+ /*min_progress_size=*/std::min(state_.string_length, 1024u));
881
+ return false;
911
882
  }
912
- return ValidateHeaderKeyIsLegal(key);
913
883
  }
914
884
 
915
- // Parse an index encoded key and a string encoded value
916
- absl::optional<HPackTable::Memento> ParseIdxKey(uint32_t index) {
917
- const auto* elem = table_->Lookup(index);
918
- if (GPR_UNLIKELY(elem == nullptr)) {
919
- InvalidHPackIndexError(index);
920
- return absl::optional<HPackTable::Memento>();
885
+ bool SkipKeyBody() {
886
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kSkippingKeyBody);
887
+ if (!SkipStringBody()) return false;
888
+ input_->UpdateFrontier();
889
+ state_.parse_state = ParseState::kSkippingValueLength;
890
+ return SkipValueLength();
891
+ }
892
+
893
+ bool SkipValueLength() {
894
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kSkippingValueLength);
895
+ auto pfx = input_->ParseStringPrefix();
896
+ if (!pfx.has_value()) return false;
897
+ state_.string_length = pfx->length;
898
+ input_->UpdateFrontier();
899
+ state_.parse_state = ParseState::kSkippingValueBody;
900
+ return SkipValueBody();
901
+ }
902
+
903
+ bool SkipValueBody() {
904
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kSkippingValueBody);
905
+ if (!SkipStringBody()) return false;
906
+ input_->UpdateFrontier();
907
+ state_.parse_state = ParseState::kTop;
908
+ if (state_.add_to_table) {
909
+ state_.hpack_table.AddLargerThanCurrentTableSize();
921
910
  }
922
- MementoBuilder builder(input_, elem->md.key(), elem->parse_status);
923
- auto value = ParseValueString(elem->md.is_binary_header());
924
- if (!builder.HandleParseResult(value.status)) return absl::nullopt;
925
- return builder.Build(elem->md.WithNewValue(
926
- value.value.Take(), value.wire_size, builder.ErrorHandler()));
927
- };
911
+ return true;
912
+ }
928
913
 
929
- // Parse a varint index encoded key and a string encoded value
930
- absl::optional<HPackTable::Memento> ParseVarIdxKey(uint32_t offset) {
931
- auto index = input_->ParseVarint(offset);
932
- if (GPR_UNLIKELY(!index.has_value())) return absl::nullopt;
933
- return ParseIdxKey(*index);
914
+ bool ParseValueLength() {
915
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kParsingValueLength);
916
+ auto pfx = input_->ParseStringPrefix();
917
+ if (!pfx.has_value()) return false;
918
+ state_.is_string_huff_compressed = pfx->huff;
919
+ state_.string_length = pfx->length;
920
+ input_->UpdateFrontier();
921
+ if (ShouldSkipParsingString(state_.string_length)) {
922
+ input_->SetErrorAndContinueParsing(
923
+ HpackParseResult::HardMetadataLimitExceededByValueError(
924
+ Match(
925
+ state_.key, [](const Slice& s) { return s.as_string_view(); },
926
+ [](const HPackTable::Memento* m) { return m->md.key(); }),
927
+ state_.string_length,
928
+ state_.metadata_early_detection.hard_limit()));
929
+ metadata_buffer_ = nullptr;
930
+ state_.parse_state = ParseState::kSkippingValueBody;
931
+ return SkipValueBody();
932
+ } else {
933
+ state_.parse_state = ParseState::kParsingValueBody;
934
+ return ParseValueBody();
935
+ }
934
936
  }
935
937
 
936
- // Parse a string, figuring out if it's binary or not by the key name.
937
- String::ParseResult ParseValueString(bool is_binary) {
938
- if (is_binary) {
939
- return String::ParseBinary(input_);
938
+ bool ParseValueBody() {
939
+ GPR_DEBUG_ASSERT(state_.parse_state == ParseState::kParsingValueBody);
940
+ auto value =
941
+ state_.is_binary_header
942
+ ? String::ParseBinary(input_, state_.is_string_huff_compressed,
943
+ state_.string_length)
944
+ : String::Parse(input_, state_.is_string_huff_compressed,
945
+ state_.string_length);
946
+ HpackParseResult& status = state_.frame_error;
947
+ absl::string_view key_string;
948
+ if (auto* s = absl::get_if<Slice>(&state_.key)) {
949
+ key_string = s->as_string_view();
950
+ if (status.ok()) {
951
+ auto r = ValidateKey(key_string);
952
+ if (r != ValidateMetadataResult::kOk) {
953
+ input_->SetErrorAndContinueParsing(
954
+ HpackParseResult::InvalidMetadataError(r, key_string));
955
+ }
956
+ }
940
957
  } else {
941
- return String::Parse(input_);
958
+ const auto* memento = absl::get<const HPackTable::Memento*>(state_.key);
959
+ key_string = memento->md.key();
960
+ if (status.ok() && !memento->parse_status.ok()) {
961
+ input_->SetErrorAndContinueParsing(memento->parse_status);
962
+ }
963
+ }
964
+ switch (value.status) {
965
+ case HpackParseStatus::kOk:
966
+ break;
967
+ case HpackParseStatus::kEof:
968
+ GPR_DEBUG_ASSERT(input_->eof_error());
969
+ return false;
970
+ default: {
971
+ auto result =
972
+ HpackParseResult::FromStatusWithKey(value.status, key_string);
973
+ if (result.stream_error()) {
974
+ input_->SetErrorAndContinueParsing(std::move(result));
975
+ break;
976
+ } else {
977
+ input_->SetErrorAndStopParsing(std::move(result));
978
+ return false;
979
+ }
980
+ }
981
+ }
982
+ auto value_slice = value.value.Take();
983
+ const auto transport_size =
984
+ key_string.size() + value.wire_size + hpack_constants::kEntryOverhead;
985
+ auto md = grpc_metadata_batch::Parse(
986
+ key_string, std::move(value_slice), transport_size,
987
+ [key_string, &status, this](absl::string_view message, const Slice&) {
988
+ if (!status.ok()) return;
989
+ input_->SetErrorAndContinueParsing(
990
+ HpackParseResult::MetadataParseError(key_string));
991
+ gpr_log(GPR_ERROR, "Error parsing '%s' metadata: %s",
992
+ std::string(key_string).c_str(),
993
+ std::string(message).c_str());
994
+ });
995
+ HPackTable::Memento memento{std::move(md),
996
+ status.PersistentStreamErrorOrOk()};
997
+ input_->UpdateFrontier();
998
+ state_.parse_state = ParseState::kTop;
999
+ if (state_.add_to_table) {
1000
+ return FinishHeaderAndAddToTable(std::move(memento));
1001
+ } else {
1002
+ FinishHeaderOmitFromTable(memento);
1003
+ return true;
942
1004
  }
943
1005
  }
944
1006
 
1007
+ ValidateMetadataResult ValidateKey(absl::string_view key) {
1008
+ if (key == HttpSchemeMetadata::key() || key == HttpMethodMetadata::key() ||
1009
+ key == HttpAuthorityMetadata::key() || key == HttpPathMetadata::key() ||
1010
+ key == HttpStatusMetadata::key()) {
1011
+ return ValidateMetadataResult::kOk;
1012
+ }
1013
+ return ValidateHeaderKeyIsLegal(key);
1014
+ }
1015
+
945
1016
  // Emit an indexed field
946
1017
  bool FinishIndexed(absl::optional<uint32_t> index) {
947
- *dynamic_table_updates_allowed_ = 0;
1018
+ state_.dynamic_table_updates_allowed = 0;
948
1019
  if (!index.has_value()) return false;
949
- const auto* elem = table_->Lookup(*index);
1020
+ const auto* elem = state_.hpack_table.Lookup(*index);
950
1021
  if (GPR_UNLIKELY(elem == nullptr)) {
951
1022
  InvalidHPackIndexError(*index);
952
1023
  return false;
@@ -958,15 +1029,16 @@ class HPackParser::Parser {
958
1029
  // finish parsing a max table size change
959
1030
  bool FinishMaxTableSize(absl::optional<uint32_t> size) {
960
1031
  if (!size.has_value()) return false;
961
- if (*dynamic_table_updates_allowed_ == 0) {
962
- input_->SetErrorAndStopParsing(absl::InternalError(
963
- "More than two max table size changes in a single frame"));
1032
+ if (state_.dynamic_table_updates_allowed == 0) {
1033
+ input_->SetErrorAndStopParsing(
1034
+ HpackParseResult::TooManyDynamicTableSizeChangesError());
964
1035
  return false;
965
1036
  }
966
- (*dynamic_table_updates_allowed_)--;
967
- grpc_error_handle err = table_->SetCurrentTableSize(*size);
968
- if (!err.ok()) {
969
- input_->SetErrorAndStopParsing(std::move(err));
1037
+ state_.dynamic_table_updates_allowed--;
1038
+ if (!state_.hpack_table.SetCurrentTableSize(*size)) {
1039
+ input_->SetErrorAndStopParsing(
1040
+ HpackParseResult::IllegalTableSizeChangeError(
1041
+ *size, state_.hpack_table.max_bytes()));
970
1042
  return false;
971
1043
  }
972
1044
  return true;
@@ -975,51 +1047,13 @@ class HPackParser::Parser {
975
1047
  // Set an invalid hpack index error if no error has been set. Returns result
976
1048
  // unmodified.
977
1049
  void InvalidHPackIndexError(uint32_t index) {
978
- input_->SetErrorAndStopParsing(grpc_error_set_int(
979
- grpc_error_set_int(absl::InternalError("Invalid HPACK index received"),
980
- StatusIntProperty::kIndex,
981
- static_cast<intptr_t>(index)),
982
- StatusIntProperty::kSize,
983
- static_cast<intptr_t>(this->table_->num_entries())));
984
- }
985
-
986
- GPR_ATTRIBUTE_NOINLINE
987
- void HandleMetadataParseError(const absl::Status& status) {
988
- if (metadata_buffer_ != nullptr) {
989
- metadata_buffer_->Clear();
990
- metadata_buffer_ = nullptr;
991
- }
992
- // StreamId is used as a signal to skip this stream but keep the connection
993
- // alive
994
- input_->SetErrorAndContinueParsing(status);
995
- }
996
-
997
- GPR_ATTRIBUTE_NOINLINE
998
- void HandleMetadataHardSizeLimitExceeded(const HPackTable::Memento& md) {
999
- // Collect a summary of sizes so far for debugging
1000
- // Do not collect contents, for fear of exposing PII.
1001
- std::string summary;
1002
- std::string error_message;
1003
- if (metadata_buffer_ != nullptr) {
1004
- MetadataSizeLimitExceededEncoder encoder(summary);
1005
- metadata_buffer_->Encode(&encoder);
1006
- }
1007
- summary = absl::StrCat("; adding ", md.md.key(), " (length ",
1008
- md.md.transport_size(), "B)",
1009
- summary.empty() ? "" : " to ", summary);
1010
- error_message = absl::StrCat(
1011
- "received metadata size exceeds hard limit (", *frame_length_, " vs. ",
1012
- metadata_early_detection_->hard_limit(), ")", summary);
1013
- HandleMetadataParseError(absl::ResourceExhaustedError(error_message));
1050
+ input_->SetErrorAndStopParsing(
1051
+ HpackParseResult::InvalidHpackIndexError(index));
1014
1052
  }
1015
1053
 
1016
1054
  Input* const input_;
1017
- grpc_metadata_batch* metadata_buffer_;
1018
- HPackTable* const table_;
1019
- uint8_t* const dynamic_table_updates_allowed_;
1020
- uint32_t* const frame_length_;
1021
- // Random early detection of metadata size limits.
1022
- RandomEarlyDetection* metadata_early_detection_;
1055
+ grpc_metadata_batch*& metadata_buffer_;
1056
+ InterSliceState& state_;
1023
1057
  const LogInfo log_info_;
1024
1058
  };
1025
1059
 
@@ -1051,9 +1085,8 @@ void HPackParser::BeginFrame(grpc_metadata_batch* metadata_buffer,
1051
1085
  }
1052
1086
  boundary_ = boundary;
1053
1087
  priority_ = priority;
1054
- dynamic_table_updates_allowed_ = 2;
1055
- frame_length_ = 0;
1056
- metadata_early_detection_ = RandomEarlyDetection(
1088
+ state_.dynamic_table_updates_allowed = 2;
1089
+ state_.metadata_early_detection.SetLimits(
1057
1090
  /*soft_limit=*/metadata_size_soft_limit,
1058
1091
  /*hard_limit=*/metadata_size_hard_limit);
1059
1092
  log_info_ = log_info;
@@ -1061,36 +1094,43 @@ void HPackParser::BeginFrame(grpc_metadata_batch* metadata_buffer,
1061
1094
 
1062
1095
  grpc_error_handle HPackParser::Parse(const grpc_slice& slice, bool is_last) {
1063
1096
  if (GPR_UNLIKELY(!unparsed_bytes_.empty())) {
1097
+ unparsed_bytes_.insert(unparsed_bytes_.end(), GRPC_SLICE_START_PTR(slice),
1098
+ GRPC_SLICE_END_PTR(slice));
1099
+ if (!(is_last && is_boundary()) &&
1100
+ unparsed_bytes_.size() < min_progress_size_) {
1101
+ // We wouldn't make progress anyway, skip out.
1102
+ return absl::OkStatus();
1103
+ }
1064
1104
  std::vector<uint8_t> buffer = std::move(unparsed_bytes_);
1065
- buffer.insert(buffer.end(), GRPC_SLICE_START_PTR(slice),
1066
- GRPC_SLICE_END_PTR(slice));
1067
- return ParseInput(
1068
- Input(nullptr, buffer.data(), buffer.data() + buffer.size()), is_last);
1105
+ return ParseInput(Input(nullptr, buffer.data(),
1106
+ buffer.data() + buffer.size(), state_.frame_error),
1107
+ is_last);
1069
1108
  }
1070
1109
  return ParseInput(Input(slice.refcount, GRPC_SLICE_START_PTR(slice),
1071
- GRPC_SLICE_END_PTR(slice)),
1110
+ GRPC_SLICE_END_PTR(slice), state_.frame_error),
1072
1111
  is_last);
1073
1112
  }
1074
1113
 
1075
1114
  grpc_error_handle HPackParser::ParseInput(Input input, bool is_last) {
1076
1115
  ParseInputInner(&input);
1077
- if (is_last) {
1078
- if (metadata_early_detection_.Reject(frame_length_)) {
1116
+ if (is_last && is_boundary()) {
1117
+ if (state_.metadata_early_detection.Reject(state_.frame_length)) {
1079
1118
  HandleMetadataSoftSizeLimitExceeded(&input);
1080
1119
  }
1081
- global_stats().IncrementHttp2MetadataSize(frame_length_);
1082
- }
1083
- if (input.eof_error()) {
1084
- if (GPR_UNLIKELY(is_last && is_boundary())) {
1085
- auto err = input.TakeError();
1086
- if (!err.ok() && !IsStreamError(err)) return err;
1087
- return absl::InternalError(
1088
- "Incomplete header at the end of a header/continuation sequence");
1120
+ global_stats().IncrementHttp2MetadataSize(state_.frame_length);
1121
+ if (!state_.frame_error.connection_error() &&
1122
+ (input.eof_error() || state_.parse_state != ParseState::kTop)) {
1123
+ state_.frame_error = HpackParseResult::IncompleteHeaderAtBoundaryError();
1124
+ }
1125
+ state_.frame_length = 0;
1126
+ return std::exchange(state_.frame_error, HpackParseResult()).Materialize();
1127
+ } else {
1128
+ if (input.eof_error() && !state_.frame_error.connection_error()) {
1129
+ unparsed_bytes_ = std::vector<uint8_t>(input.frontier(), input.end_ptr());
1130
+ min_progress_size_ = input.min_progress_size();
1089
1131
  }
1090
- unparsed_bytes_ = std::vector<uint8_t>(input.frontier(), input.end_ptr());
1091
- return input.TakeError();
1132
+ return state_.frame_error.Materialize();
1092
1133
  }
1093
- return input.TakeError();
1094
1134
  }
1095
1135
 
1096
1136
  void HPackParser::ParseInputInner(Input* input) {
@@ -1099,7 +1139,7 @@ void HPackParser::ParseInputInner(Input* input) {
1099
1139
  break;
1100
1140
  case Priority::Included: {
1101
1141
  if (input->remaining() < 5) {
1102
- input->UnexpectedEOF();
1142
+ input->UnexpectedEOF(/*min_progress_size=*/5);
1103
1143
  return;
1104
1144
  }
1105
1145
  input->Advance(5);
@@ -1108,10 +1148,8 @@ void HPackParser::ParseInputInner(Input* input) {
1108
1148
  }
1109
1149
  }
1110
1150
  while (!input->end_of_stream()) {
1111
- if (GPR_UNLIKELY(!Parser(input, metadata_buffer_, &table_,
1112
- &dynamic_table_updates_allowed_, &frame_length_,
1113
- &metadata_early_detection_, log_info_)
1114
- .Parse())) {
1151
+ if (GPR_UNLIKELY(
1152
+ !Parser(input, metadata_buffer_, state_, log_info_).Parse())) {
1115
1153
  return;
1116
1154
  }
1117
1155
  input->UpdateFrontier();
@@ -1121,24 +1159,10 @@ void HPackParser::ParseInputInner(Input* input) {
1121
1159
  void HPackParser::FinishFrame() { metadata_buffer_ = nullptr; }
1122
1160
 
1123
1161
  void HPackParser::HandleMetadataSoftSizeLimitExceeded(Input* input) {
1124
- // Collect a summary of sizes so far for debugging
1125
- // Do not collect contents, for fear of exposing PII.
1126
- std::string summary;
1127
- std::string error_message;
1128
- if (metadata_buffer_ != nullptr) {
1129
- MetadataSizeLimitExceededEncoder encoder(summary);
1130
- metadata_buffer_->Encode(&encoder);
1131
- }
1132
- error_message = absl::StrCat(
1133
- "received metadata size exceeds soft limit (", frame_length_, " vs. ",
1134
- metadata_early_detection_.soft_limit(),
1135
- "), rejecting requests with some random probability", summary);
1136
- if (metadata_buffer_ != nullptr) {
1137
- metadata_buffer_->Clear();
1138
- metadata_buffer_ = nullptr;
1139
- }
1140
1162
  input->SetErrorAndContinueParsing(
1141
- absl::ResourceExhaustedError(error_message));
1163
+ HpackParseResult::SoftMetadataLimitExceededError(
1164
+ std::exchange(metadata_buffer_, nullptr), state_.frame_length,
1165
+ state_.metadata_early_detection.soft_limit()));
1142
1166
  }
1143
1167
 
1144
1168
  } // namespace grpc_core