grpc 1.72.0 → 1.73.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1034) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +23 -6
  3. data/include/grpc/event_engine/event_engine.h +125 -8
  4. data/include/grpc/event_engine/internal/write_event.h +34 -0
  5. data/include/grpc/impl/channel_arg_names.h +17 -9
  6. data/include/grpc/impl/compression_types.h +3 -2
  7. data/include/grpc/impl/slice_type.h +1 -1
  8. data/include/grpc/support/json.h +3 -21
  9. data/include/grpc/support/port_platform.h +8 -5
  10. data/src/core/call/call_filters.h +28 -19
  11. data/src/core/call/call_spine.h +2 -0
  12. data/src/core/call/metadata.h +17 -0
  13. data/src/core/channelz/channel_trace.cc +50 -42
  14. data/src/core/channelz/channel_trace.h +35 -4
  15. data/src/core/channelz/channelz.cc +338 -125
  16. data/src/core/channelz/channelz.h +276 -34
  17. data/src/core/channelz/channelz_registry.cc +322 -117
  18. data/src/core/channelz/channelz_registry.h +179 -21
  19. data/src/core/channelz/ztrace_collector.h +315 -0
  20. data/src/core/client_channel/client_channel.cc +30 -29
  21. data/src/core/client_channel/client_channel_filter.cc +21 -20
  22. data/src/core/client_channel/client_channel_filter.h +0 -2
  23. data/src/core/client_channel/connector.h +0 -3
  24. data/src/core/client_channel/global_subchannel_pool.cc +68 -7
  25. data/src/core/client_channel/global_subchannel_pool.h +37 -4
  26. data/src/core/client_channel/subchannel.cc +7 -9
  27. data/src/core/client_channel/subchannel.h +2 -8
  28. data/src/core/client_channel/subchannel_pool_interface.cc +5 -6
  29. data/src/core/client_channel/subchannel_pool_interface.h +11 -1
  30. data/src/core/config/config_vars.cc +11 -1
  31. data/src/core/config/config_vars.h +8 -0
  32. data/src/core/config/core_configuration.cc +50 -11
  33. data/src/core/config/core_configuration.h +89 -7
  34. data/src/core/credentials/call/external/aws_request_signer.cc +3 -2
  35. data/src/core/credentials/call/external/url_external_account_credentials.cc +2 -2
  36. data/src/core/credentials/call/gcp_service_account_identity/gcp_service_account_identity_credentials.cc +1 -1
  37. data/src/core/credentials/call/jwt/jwt_verifier.cc +4 -4
  38. data/src/core/credentials/call/oauth2/oauth2_credentials.cc +4 -2
  39. data/src/core/credentials/transport/alts/alts_security_connector.cc +9 -8
  40. data/src/core/credentials/transport/google_default/google_default_credentials.cc +3 -3
  41. data/src/core/credentials/transport/ssl/ssl_credentials.cc +2 -2
  42. data/src/core/credentials/transport/ssl/ssl_security_connector.cc +41 -11
  43. data/src/core/credentials/transport/ssl/ssl_security_connector.h +2 -1
  44. data/src/core/credentials/transport/tls/ssl_utils.cc +18 -0
  45. data/src/core/credentials/transport/tls/ssl_utils.h +5 -0
  46. data/src/core/credentials/transport/tls/tls_security_connector.cc +2 -1
  47. data/src/core/ext/filters/channel_idle/legacy_channel_idle_filter.cc +6 -3
  48. data/src/core/ext/filters/http/message_compress/compression_filter.h +34 -4
  49. data/src/core/ext/filters/http/server/http_server_filter.cc +1 -1
  50. data/src/core/ext/filters/http/server/http_server_filter.h +14 -3
  51. data/src/core/ext/transport/chttp2/chttp2_plugin.cc +40 -0
  52. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +11 -112
  53. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +3 -0
  54. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +33 -962
  55. data/src/core/ext/transport/chttp2/server/chttp2_server.h +5 -1
  56. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +129 -47
  57. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +0 -3
  58. data/src/core/ext/transport/chttp2/transport/flow_control.h +18 -0
  59. data/src/core/ext/transport/chttp2/transport/frame.cc +213 -105
  60. data/src/core/ext/transport/chttp2/transport/frame.h +78 -6
  61. data/src/core/ext/transport/chttp2/transport/frame_data.cc +10 -0
  62. data/src/core/ext/transport/chttp2/transport/frame_data.h +2 -0
  63. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +15 -3
  64. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +5 -3
  65. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +2 -0
  66. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +11 -4
  67. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +3 -1
  68. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +19 -1
  69. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +4 -0
  70. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +7 -0
  71. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +2 -0
  72. data/src/core/ext/transport/chttp2/transport/http2_settings.h +26 -0
  73. data/src/core/ext/transport/chttp2/transport/http2_status.h +358 -1
  74. data/src/core/ext/transport/chttp2/transport/http2_ztrace_collector.h +252 -0
  75. data/src/core/ext/transport/chttp2/transport/internal.h +29 -5
  76. data/src/core/ext/transport/chttp2/transport/internal_channel_arg_names.h +24 -0
  77. data/src/core/ext/transport/chttp2/transport/parsing.cc +36 -21
  78. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.cc +10 -9
  79. data/src/core/ext/transport/chttp2/transport/ping_rate_policy.h +6 -0
  80. data/src/core/ext/transport/chttp2/transport/writing.cc +60 -49
  81. data/src/core/ext/transport/inproc/inproc_transport.cc +7 -2
  82. data/src/core/ext/transport/inproc/legacy_inproc_transport.cc +6 -2
  83. data/src/core/ext/upb-gen/envoy/admin/v3/certs.upb.h +4 -0
  84. data/src/core/ext/upb-gen/envoy/config/accesslog/v3/accesslog.upb.h +12 -0
  85. data/src/core/ext/upb-gen/envoy/config/bootstrap/v3/bootstrap.upb.h +12 -22
  86. data/src/core/ext/upb-gen/envoy/config/cluster/v3/cluster.upb.h +12 -22
  87. data/src/core/ext/upb-gen/envoy/config/common/matcher/v3/matcher.upb.h +28 -22
  88. data/src/core/ext/upb-gen/envoy/config/core/v3/address.upb.h +12 -0
  89. data/src/core/ext/upb-gen/envoy/config/core/v3/base.upb.h +24 -67
  90. data/src/core/ext/upb-gen/envoy/config/core/v3/config_source.upb.h +4 -0
  91. data/src/core/ext/upb-gen/envoy/config/core/v3/event_service_config.upb.h +4 -0
  92. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb.h +29 -31
  93. data/src/core/ext/upb-gen/envoy/config/core/v3/grpc_service.upb_minitable.c +2 -2
  94. data/src/core/ext/upb-gen/envoy/config/core/v3/health_check.upb.h +12 -0
  95. data/src/core/ext/upb-gen/envoy/config/core/v3/http_uri.upb.h +4 -0
  96. data/src/core/ext/upb-gen/envoy/config/core/v3/protocol.upb.h +8 -0
  97. data/src/core/ext/upb-gen/envoy/config/core/v3/socket_option.upb.h +4 -0
  98. data/src/core/ext/upb-gen/envoy/config/core/v3/substitution_format_string.upb.h +4 -0
  99. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint.upb.h +0 -23
  100. data/src/core/ext/upb-gen/envoy/config/endpoint/v3/endpoint_components.upb.h +8 -0
  101. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener.upb.h +8 -0
  102. data/src/core/ext/upb-gen/envoy/config/listener/v3/listener_components.upb.h +12 -0
  103. data/src/core/ext/upb-gen/envoy/config/metrics/v3/stats.upb.h +20 -0
  104. data/src/core/ext/upb-gen/envoy/config/overload/v3/overload.upb.h +12 -0
  105. data/src/core/ext/upb-gen/envoy/config/rbac/v3/rbac.upb.h +8 -22
  106. data/src/core/ext/upb-gen/envoy/config/route/v3/route.upb.h +0 -23
  107. data/src/core/ext/upb-gen/envoy/config/route/v3/route_components.upb.h +64 -66
  108. data/src/core/ext/upb-gen/envoy/config/route/v3/scoped_route.upb.h +4 -0
  109. data/src/core/ext/upb-gen/envoy/config/tap/v3/common.upb.h +12 -0
  110. data/src/core/ext/upb-gen/envoy/config/trace/v3/http_tracer.upb.h +4 -0
  111. data/src/core/ext/upb-gen/envoy/config/trace/v3/skywalking.upb.h +4 -0
  112. data/src/core/ext/upb-gen/envoy/data/accesslog/v3/accesslog.upb.h +4 -95
  113. data/src/core/ext/upb-gen/envoy/extensions/filters/common/fault/v3/fault.upb.h +8 -0
  114. data/src/core/ext/upb-gen/envoy/extensions/filters/http/fault/v3/fault.upb.h +4 -0
  115. data/src/core/ext/upb-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upb.h +4 -0
  116. data/src/core/ext/upb-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +28 -0
  117. data/src/core/ext/upb-gen/envoy/extensions/load_balancing_policies/common/v3/common.upb.h +4 -0
  118. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/common.upb.h +4 -0
  119. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +4 -0
  120. data/src/core/ext/upb-gen/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +12 -0
  121. data/src/core/ext/upb-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upb.h +8 -0
  122. data/src/core/ext/upb-gen/envoy/service/discovery/v3/discovery.upb.h +8 -36
  123. data/src/core/ext/upb-gen/envoy/service/status/v3/csds.upb.h +4 -0
  124. data/src/core/ext/upb-gen/envoy/type/http/v3/path_transformation.upb.h +4 -0
  125. data/src/core/ext/upb-gen/envoy/type/matcher/v3/filter_state.upb.h +4 -0
  126. data/src/core/ext/upb-gen/envoy/type/matcher/v3/metadata.upb.h +4 -0
  127. data/src/core/ext/upb-gen/envoy/type/matcher/v3/number.upb.h +4 -0
  128. data/src/core/ext/upb-gen/envoy/type/matcher/v3/path.upb.h +4 -0
  129. data/src/core/ext/upb-gen/envoy/type/matcher/v3/regex.upb.h +4 -0
  130. data/src/core/ext/upb-gen/envoy/type/matcher/v3/string.upb.h +4 -0
  131. data/src/core/ext/upb-gen/envoy/type/matcher/v3/struct.upb.h +4 -0
  132. data/src/core/ext/upb-gen/envoy/type/matcher/v3/value.upb.h +8 -0
  133. data/src/core/ext/upb-gen/envoy/type/metadata/v3/metadata.upb.h +8 -0
  134. data/src/core/ext/upb-gen/envoy/type/tracing/v3/custom_tag.upb.h +4 -0
  135. data/src/core/ext/upb-gen/envoy/type/v3/hash_policy.upb.h +4 -0
  136. data/src/core/ext/upb-gen/envoy/type/v3/ratelimit_strategy.upb.h +4 -0
  137. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/checked.upb.h +8 -44
  138. data/src/core/ext/upb-gen/google/api/expr/v1alpha1/syntax.upb.h +12 -40
  139. data/src/core/ext/upb-gen/google/api/http.upb.h +4 -0
  140. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb.h +193 -20
  141. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.c +59 -21
  142. data/src/core/ext/upb-gen/google/protobuf/descriptor.upb_minitable.h +4 -0
  143. data/src/core/ext/upb-gen/google/protobuf/struct.upb.h +4 -22
  144. data/src/core/ext/upb-gen/src/proto/grpc/gcp/altscontext.upb.h +0 -18
  145. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb.h +113 -53
  146. data/src/core/ext/upb-gen/src/proto/grpc/gcp/handshaker.upb_minitable.c +20 -14
  147. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb.h +154 -0
  148. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.c +40 -2
  149. data/src/core/ext/upb-gen/src/proto/grpc/gcp/transport_security_common.upb_minitable.h +4 -0
  150. data/src/core/ext/upb-gen/src/proto/grpc/lb/v1/load_balancer.upb.h +8 -0
  151. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls.upb.h +0 -18
  152. data/src/core/ext/upb-gen/src/proto/grpc/lookup/v1/rls_config.upb.h +0 -36
  153. data/src/core/ext/upb-gen/validate/validate.upb.h +12 -0
  154. data/src/core/ext/upb-gen/xds/core/v3/collection_entry.upb.h +4 -0
  155. data/src/core/ext/upb-gen/xds/core/v3/context_params.upb.h +0 -18
  156. data/src/core/ext/upb-gen/xds/core/v3/resource_locator.upb.h +8 -0
  157. data/src/core/ext/upb-gen/xds/data/orca/v3/orca_load_report.upb.h +0 -54
  158. data/src/core/ext/upb-gen/xds/type/matcher/v3/matcher.upb.h +20 -22
  159. data/src/core/ext/upb-gen/xds/type/matcher/v3/regex.upb.h +4 -0
  160. data/src/core/ext/upb-gen/xds/type/matcher/v3/string.upb.h +4 -0
  161. data/src/core/ext/upb-gen/xds/type/v3/cel.upb.h +4 -0
  162. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.c +123 -62
  163. data/src/core/ext/upbdefs-gen/envoy/admin/v3/certs.upbdefs.h +5 -1
  164. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.c +200 -101
  165. data/src/core/ext/upbdefs-gen/envoy/admin/v3/clusters.upbdefs.h +5 -1
  166. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.c +152 -77
  167. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump.upbdefs.h +5 -1
  168. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.c +524 -255
  169. data/src/core/ext/upbdefs-gen/envoy/admin/v3/config_dump_shared.upbdefs.h +5 -1
  170. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.c +44 -23
  171. data/src/core/ext/upbdefs-gen/envoy/admin/v3/init_dump.upbdefs.h +5 -1
  172. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.c +66 -34
  173. data/src/core/ext/upbdefs-gen/envoy/admin/v3/listeners.upbdefs.h +5 -1
  174. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.c +54 -28
  175. data/src/core/ext/upbdefs-gen/envoy/admin/v3/memory.upbdefs.h +5 -1
  176. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.c +46 -25
  177. data/src/core/ext/upbdefs-gen/envoy/admin/v3/metrics.upbdefs.h +5 -1
  178. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.c +47 -25
  179. data/src/core/ext/upbdefs-gen/envoy/admin/v3/mutex_stats.upbdefs.h +5 -1
  180. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.c +256 -126
  181. data/src/core/ext/upbdefs-gen/envoy/admin/v3/server_info.upbdefs.h +5 -1
  182. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.c +50 -28
  183. data/src/core/ext/upbdefs-gen/envoy/admin/v3/tap.upbdefs.h +5 -1
  184. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.c +55 -28
  185. data/src/core/ext/upbdefs-gen/envoy/annotations/deprecation.upbdefs.h +5 -1
  186. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.c +34 -18
  187. data/src/core/ext/upbdefs-gen/envoy/annotations/resource.upbdefs.h +5 -1
  188. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.c +414 -206
  189. data/src/core/ext/upbdefs-gen/envoy/config/accesslog/v3/accesslog.upbdefs.h +5 -1
  190. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +831 -413
  191. data/src/core/ext/upbdefs-gen/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +5 -1
  192. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +143 -73
  193. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +5 -1
  194. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.c +1132 -557
  195. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/cluster.upbdefs.h +5 -1
  196. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.c +63 -34
  197. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/filter.upbdefs.h +5 -1
  198. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.c +255 -127
  199. data/src/core/ext/upbdefs-gen/envoy/config/cluster/v3/outlier_detection.upbdefs.h +5 -1
  200. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.c +363 -178
  201. data/src/core/ext/upbdefs-gen/envoy/config/common/matcher/v3/matcher.upbdefs.h +5 -1
  202. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.c +227 -114
  203. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/address.upbdefs.h +5 -1
  204. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.c +57 -31
  205. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/backoff.upbdefs.h +5 -1
  206. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.c +596 -295
  207. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/base.upbdefs.h +5 -1
  208. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.c +271 -137
  209. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/config_source.upbdefs.h +5 -1
  210. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.c +56 -30
  211. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/event_service_config.upbdefs.h +5 -1
  212. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.c +45 -25
  213. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/extension.upbdefs.h +5 -1
  214. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.c +59 -31
  215. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_method_list.upbdefs.h +5 -1
  216. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.c +438 -217
  217. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/grpc_service.upbdefs.h +5 -1
  218. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.c +441 -221
  219. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/health_check.upbdefs.h +5 -1
  220. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.c +55 -30
  221. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_service.upbdefs.h +5 -1
  222. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.c +57 -31
  223. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/http_uri.upbdefs.h +5 -1
  224. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.c +619 -303
  225. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/protocol.upbdefs.h +5 -1
  226. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.c +70 -36
  227. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/proxy_protocol.upbdefs.h +5 -1
  228. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.c +62 -33
  229. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/resolver.upbdefs.h +5 -1
  230. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.c +47 -25
  231. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_cmsg_headers.upbdefs.h +5 -1
  232. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.c +97 -49
  233. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/socket_option.upbdefs.h +5 -1
  234. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.c +97 -51
  235. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/substitution_format_string.upbdefs.h +5 -1
  236. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.c +51 -27
  237. data/src/core/ext/upbdefs-gen/envoy/config/core/v3/udp_socket_config.upbdefs.h +5 -1
  238. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.c +147 -76
  239. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint.upbdefs.h +5 -1
  240. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +230 -116
  241. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +5 -1
  242. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.c +277 -138
  243. data/src/core/ext/upbdefs-gen/envoy/config/endpoint/v3/load_report.upbdefs.h +5 -1
  244. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.c +48 -26
  245. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/api_listener.upbdefs.h +5 -1
  246. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.c +388 -197
  247. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener.upbdefs.h +5 -1
  248. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.c +304 -153
  249. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/listener_components.upbdefs.h +5 -1
  250. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.c +173 -90
  251. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/quic_config.upbdefs.h +5 -1
  252. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.c +90 -47
  253. data/src/core/ext/upbdefs-gen/envoy/config/listener/v3/udp_listener_config.upbdefs.h +5 -1
  254. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.c +98 -51
  255. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/metrics_service.upbdefs.h +5 -1
  256. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.c +196 -99
  257. data/src/core/ext/upbdefs-gen/envoy/config/metrics/v3/stats.upbdefs.h +5 -1
  258. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.c +237 -118
  259. data/src/core/ext/upbdefs-gen/envoy/config/overload/v3/overload.upbdefs.h +5 -1
  260. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.c +418 -210
  261. data/src/core/ext/upbdefs-gen/envoy/config/rbac/v3/rbac.upbdefs.h +5 -1
  262. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.c +194 -99
  263. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route.upbdefs.h +5 -1
  264. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.c +2003 -973
  265. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/route_components.upbdefs.h +5 -1
  266. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.c +101 -53
  267. data/src/core/ext/upbdefs-gen/envoy/config/route/v3/scoped_route.upbdefs.h +5 -1
  268. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.c +352 -176
  269. data/src/core/ext/upbdefs-gen/envoy/config/tap/v3/common.upbdefs.h +5 -1
  270. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.c +79 -42
  271. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/datadog.upbdefs.h +5 -1
  272. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.c +67 -37
  273. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/dynamic_ot.upbdefs.h +5 -1
  274. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.c +63 -34
  275. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/http_tracer.upbdefs.h +5 -1
  276. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.c +88 -47
  277. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/lightstep.upbdefs.h +5 -1
  278. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.c +80 -43
  279. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/opentelemetry.upbdefs.h +5 -1
  280. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.c +53 -29
  281. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/service.upbdefs.h +5 -1
  282. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.c +86 -46
  283. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/skywalking.upbdefs.h +5 -1
  284. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.c +55 -32
  285. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/trace.upbdefs.h +5 -1
  286. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.c +91 -49
  287. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/xray.upbdefs.h +5 -1
  288. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.c +105 -55
  289. data/src/core/ext/upbdefs-gen/envoy/config/trace/v3/zipkin.upbdefs.h +5 -1
  290. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.c +775 -379
  291. data/src/core/ext/upbdefs-gen/envoy/data/accesslog/v3/accesslog.upbdefs.h +5 -1
  292. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +52 -28
  293. data/src/core/ext/upbdefs-gen/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +5 -1
  294. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +134 -68
  295. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +5 -1
  296. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +189 -96
  297. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +5 -1
  298. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.c +116 -61
  299. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/gcp_authn/v3/gcp_authn.upbdefs.h +5 -1
  300. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +112 -58
  301. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +5 -1
  302. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.c +160 -82
  303. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/router/v3/router.upbdefs.h +5 -1
  304. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.c +75 -39
  305. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/http/stateful_session/v3/stateful_session.upbdefs.h +5 -1
  306. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +1161 -570
  307. data/src/core/ext/upbdefs-gen/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +5 -1
  308. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.c +52 -28
  309. data/src/core/ext/upbdefs-gen/envoy/extensions/http/stateful_session/cookie/v3/cookie.upbdefs.h +5 -1
  310. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.c +55 -29
  311. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/http_11_proxy/v3/upstream_http_11_connect.upbdefs.h +5 -1
  312. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +48 -26
  313. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +5 -1
  314. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +390 -194
  315. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +5 -1
  316. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +126 -65
  317. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +5 -1
  318. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +498 -246
  319. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +5 -1
  320. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +74 -38
  321. data/src/core/ext/upbdefs-gen/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +5 -1
  322. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.c +221 -110
  323. data/src/core/ext/upbdefs-gen/envoy/extensions/upstreams/http/v3/http_protocol_options.upbdefs.h +5 -1
  324. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.c +68 -36
  325. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/ads.upbdefs.h +5 -1
  326. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.c +378 -187
  327. data/src/core/ext/upbdefs-gen/envoy/service/discovery/v3/discovery.upbdefs.h +5 -1
  328. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.c +100 -52
  329. data/src/core/ext/upbdefs-gen/envoy/service/load_stats/v3/lrs.upbdefs.h +5 -1
  330. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.c +257 -129
  331. data/src/core/ext/upbdefs-gen/envoy/service/status/v3/csds.upbdefs.h +5 -1
  332. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.c +44 -24
  333. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/cookie.upbdefs.h +5 -1
  334. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.c +68 -35
  335. data/src/core/ext/upbdefs-gen/envoy/type/http/v3/path_transformation.upbdefs.h +5 -1
  336. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.c +38 -20
  337. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/address.upbdefs.h +5 -1
  338. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.c +59 -32
  339. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/filter_state.upbdefs.h +5 -1
  340. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.c +65 -34
  341. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/http_inputs.upbdefs.h +5 -1
  342. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.c +72 -38
  343. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/metadata.upbdefs.h +5 -1
  344. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.c +57 -31
  345. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/node.upbdefs.h +5 -1
  346. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.c +52 -29
  347. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/number.upbdefs.h +5 -1
  348. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.c +51 -28
  349. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/path.upbdefs.h +5 -1
  350. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.c +89 -47
  351. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/regex.upbdefs.h +5 -1
  352. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.c +37 -20
  353. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/status_code_input.upbdefs.h +5 -1
  354. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.c +89 -47
  355. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/string.upbdefs.h +5 -1
  356. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.c +67 -35
  357. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/struct.upbdefs.h +5 -1
  358. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.c +112 -58
  359. data/src/core/ext/upbdefs-gen/envoy/type/matcher/v3/value.upbdefs.h +5 -1
  360. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.c +110 -56
  361. data/src/core/ext/upbdefs-gen/envoy/type/metadata/v3/metadata.upbdefs.h +5 -1
  362. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.c +123 -62
  363. data/src/core/ext/upbdefs-gen/envoy/type/tracing/v3/custom_tag.upbdefs.h +5 -1
  364. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.c +59 -31
  365. data/src/core/ext/upbdefs-gen/envoy/type/v3/hash_policy.upbdefs.h +5 -1
  366. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.c +30 -16
  367. data/src/core/ext/upbdefs-gen/envoy/type/v3/http.upbdefs.h +5 -1
  368. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.c +143 -72
  369. data/src/core/ext/upbdefs-gen/envoy/type/v3/http_status.upbdefs.h +5 -1
  370. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.c +61 -32
  371. data/src/core/ext/upbdefs-gen/envoy/type/v3/percent.upbdefs.h +5 -1
  372. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.c +51 -27
  373. data/src/core/ext/upbdefs-gen/envoy/type/v3/range.upbdefs.h +5 -1
  374. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.c +85 -45
  375. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_strategy.upbdefs.h +5 -1
  376. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.c +35 -19
  377. data/src/core/ext/upbdefs-gen/envoy/type/v3/ratelimit_unit.upbdefs.h +5 -1
  378. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.c +44 -23
  379. data/src/core/ext/upbdefs-gen/envoy/type/v3/semantic_version.upbdefs.h +5 -1
  380. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.c +61 -33
  381. data/src/core/ext/upbdefs-gen/envoy/type/v3/token_bucket.upbdefs.h +5 -1
  382. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.c +35 -19
  383. data/src/core/ext/upbdefs-gen/google/api/annotations.upbdefs.h +5 -1
  384. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.c +272 -133
  385. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/checked.upbdefs.h +5 -1
  386. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.c +315 -154
  387. data/src/core/ext/upbdefs-gen/google/api/expr/v1alpha1/syntax.upbdefs.h +5 -1
  388. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.c +64 -33
  389. data/src/core/ext/upbdefs-gen/google/api/http.upbdefs.h +5 -1
  390. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.c +35 -19
  391. data/src/core/ext/upbdefs-gen/google/api/httpbody.upbdefs.h +5 -1
  392. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.c +26 -15
  393. data/src/core/ext/upbdefs-gen/google/protobuf/any.upbdefs.h +5 -1
  394. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.c +1106 -508
  395. data/src/core/ext/upbdefs-gen/google/protobuf/descriptor.upbdefs.h +10 -1
  396. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.c +28 -16
  397. data/src/core/ext/upbdefs-gen/google/protobuf/duration.upbdefs.h +5 -1
  398. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.c +23 -13
  399. data/src/core/ext/upbdefs-gen/google/protobuf/empty.upbdefs.h +5 -1
  400. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.c +69 -35
  401. data/src/core/ext/upbdefs-gen/google/protobuf/struct.upbdefs.h +5 -1
  402. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.c +29 -16
  403. data/src/core/ext/upbdefs-gen/google/protobuf/timestamp.upbdefs.h +5 -1
  404. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.c +51 -26
  405. data/src/core/ext/upbdefs-gen/google/protobuf/wrappers.upbdefs.h +5 -1
  406. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.c +32 -17
  407. data/src/core/ext/upbdefs-gen/google/rpc/status.upbdefs.h +5 -1
  408. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +161 -79
  409. data/src/core/ext/upbdefs-gen/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +5 -1
  410. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.c +84 -42
  411. data/src/core/ext/upbdefs-gen/udpa/annotations/migrate.upbdefs.h +5 -1
  412. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.c +48 -26
  413. data/src/core/ext/upbdefs-gen/udpa/annotations/security.upbdefs.h +5 -1
  414. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.c +26 -14
  415. data/src/core/ext/upbdefs-gen/udpa/annotations/sensitive.upbdefs.h +5 -1
  416. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.c +50 -26
  417. data/src/core/ext/upbdefs-gen/udpa/annotations/status.upbdefs.h +5 -1
  418. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.c +36 -19
  419. data/src/core/ext/upbdefs-gen/udpa/annotations/versioning.upbdefs.h +5 -1
  420. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.c +538 -261
  421. data/src/core/ext/upbdefs-gen/validate/validate.upbdefs.h +5 -1
  422. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.c +86 -43
  423. data/src/core/ext/upbdefs-gen/xds/annotations/v3/migrate.upbdefs.h +5 -1
  424. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.c +49 -26
  425. data/src/core/ext/upbdefs-gen/xds/annotations/v3/security.upbdefs.h +5 -1
  426. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.c +27 -15
  427. data/src/core/ext/upbdefs-gen/xds/annotations/v3/sensitive.upbdefs.h +5 -1
  428. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.c +87 -44
  429. data/src/core/ext/upbdefs-gen/xds/annotations/v3/status.upbdefs.h +5 -1
  430. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.c +37 -20
  431. data/src/core/ext/upbdefs-gen/xds/annotations/v3/versioning.upbdefs.h +5 -1
  432. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.c +30 -17
  433. data/src/core/ext/upbdefs-gen/xds/core/v3/authority.upbdefs.h +5 -1
  434. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.c +41 -23
  435. data/src/core/ext/upbdefs-gen/xds/core/v3/cidr.upbdefs.h +5 -1
  436. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.c +62 -33
  437. data/src/core/ext/upbdefs-gen/xds/core/v3/collection_entry.upbdefs.h +5 -1
  438. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.c +36 -19
  439. data/src/core/ext/upbdefs-gen/xds/core/v3/context_params.upbdefs.h +5 -1
  440. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.c +36 -20
  441. data/src/core/ext/upbdefs-gen/xds/core/v3/extension.upbdefs.h +5 -1
  442. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.c +42 -23
  443. data/src/core/ext/upbdefs-gen/xds/core/v3/resource.upbdefs.h +5 -1
  444. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.c +76 -39
  445. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_locator.upbdefs.h +5 -1
  446. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.c +45 -24
  447. data/src/core/ext/upbdefs-gen/xds/core/v3/resource_name.upbdefs.h +5 -1
  448. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.c +41 -23
  449. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/cel.upbdefs.h +5 -1
  450. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.c +53 -29
  451. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/domain.upbdefs.h +5 -1
  452. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.c +29 -16
  453. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/http_inputs.upbdefs.h +5 -1
  454. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.c +58 -32
  455. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/ip.upbdefs.h +5 -1
  456. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.c +207 -103
  457. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/matcher.upbdefs.h +5 -1
  458. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.c +95 -49
  459. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/range.upbdefs.h +5 -1
  460. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.c +38 -20
  461. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/regex.upbdefs.h +5 -1
  462. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.c +60 -31
  463. data/src/core/ext/upbdefs-gen/xds/type/matcher/v3/string.upbdefs.h +5 -1
  464. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.c +67 -36
  465. data/src/core/ext/upbdefs-gen/xds/type/v3/cel.upbdefs.h +5 -1
  466. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.c +31 -17
  467. data/src/core/ext/upbdefs-gen/xds/type/v3/range.upbdefs.h +5 -1
  468. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.c +31 -17
  469. data/src/core/ext/upbdefs-gen/xds/type/v3/typed_struct.upbdefs.h +5 -1
  470. data/src/core/handshaker/http_connect/http_proxy_mapper.cc +7 -22
  471. data/src/core/handshaker/security/legacy_secure_endpoint.cc +596 -0
  472. data/src/core/handshaker/security/secure_endpoint.cc +769 -312
  473. data/src/core/handshaker/security/secure_endpoint.h +17 -0
  474. data/src/core/handshaker/security/security_handshaker.cc +3 -3
  475. data/src/core/lib/address_utils/sockaddr_utils.cc +5 -5
  476. data/src/core/lib/channel/channel_args.h +4 -0
  477. data/src/core/lib/channel/channel_stack.cc +29 -0
  478. data/src/core/lib/channel/channel_stack.h +9 -0
  479. data/src/core/lib/channel/promise_based_filter.h +707 -299
  480. data/src/core/lib/debug/trace_flags.cc +2 -2
  481. data/src/core/lib/debug/trace_flags.h +1 -1
  482. data/src/core/lib/event_engine/cf_engine/cf_engine.cc +6 -2
  483. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.cc +4 -4
  484. data/src/core/lib/event_engine/cf_engine/cfstream_endpoint.h +14 -6
  485. data/src/core/lib/event_engine/default_event_engine_factory.cc +1 -1
  486. data/src/core/lib/event_engine/extensions/blocking_dns.h +46 -0
  487. data/src/core/lib/event_engine/extensions/channelz.h +62 -0
  488. data/src/core/lib/event_engine/extensions/tcp_trace.h +2 -2
  489. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.cc +4 -7
  490. data/src/core/lib/event_engine/posix_engine/native_posix_dns_resolver.h +3 -0
  491. data/src/core/lib/event_engine/posix_engine/posix_endpoint.cc +6 -7
  492. data/src/core/lib/event_engine/posix_engine/posix_endpoint.h +28 -22
  493. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +22 -0
  494. data/src/core/lib/event_engine/posix_engine/posix_engine.h +15 -15
  495. data/src/core/lib/event_engine/query_extensions.h +10 -21
  496. data/src/core/lib/event_engine/tcp_socket_utils.cc +10 -9
  497. data/src/core/lib/event_engine/utils.cc +34 -0
  498. data/src/core/lib/event_engine/utils.h +3 -0
  499. data/src/core/lib/event_engine/windows/windows_endpoint.cc +2 -2
  500. data/src/core/lib/event_engine/windows/windows_endpoint.h +9 -2
  501. data/src/core/lib/experiments/experiments.cc +198 -51
  502. data/src/core/lib/experiments/experiments.h +78 -35
  503. data/src/core/lib/iomgr/combiner.cc +3 -2
  504. data/src/core/lib/iomgr/ev_poll_posix.cc +4 -0
  505. data/src/core/lib/iomgr/event_engine_shims/endpoint.cc +11 -8
  506. data/src/core/lib/iomgr/fork_posix.cc +0 -7
  507. data/src/core/lib/iomgr/iomgr.cc +0 -3
  508. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +3 -0
  509. data/src/core/lib/iomgr/resolve_address_posix.cc +37 -47
  510. data/src/core/lib/iomgr/resolve_address_posix.h +15 -0
  511. data/src/core/lib/iomgr/resolve_address_windows.cc +22 -45
  512. data/src/core/lib/iomgr/resolve_address_windows.h +15 -2
  513. data/src/core/lib/iomgr/tcp_client_posix.cc +14 -6
  514. data/src/core/lib/iomgr/tcp_posix.cc +14 -12
  515. data/src/core/lib/iomgr/tcp_server_windows.cc +14 -2
  516. data/src/core/lib/promise/detail/promise_like.h +24 -0
  517. data/src/core/lib/promise/detail/seq_state.h +741 -0
  518. data/src/core/lib/promise/map.h +22 -5
  519. data/src/core/lib/promise/promise.h +2 -0
  520. data/src/core/lib/promise/seq.h +2 -0
  521. data/src/core/lib/promise/sleep.cc +6 -3
  522. data/src/core/lib/promise/try_seq.h +2 -0
  523. data/src/core/lib/resource_quota/memory_quota.cc +9 -0
  524. data/src/core/lib/resource_quota/memory_quota.h +1 -3
  525. data/src/core/lib/slice/slice_buffer.h +6 -0
  526. data/src/core/lib/surface/call.cc +4 -0
  527. data/src/core/lib/surface/channel_create.cc +61 -1
  528. data/src/core/lib/surface/init.cc +2 -2
  529. data/src/core/lib/surface/version.cc +2 -2
  530. data/src/core/lib/transport/status_conversion.cc +7 -34
  531. data/src/core/lib/transport/transport.cc +2 -2
  532. data/src/core/lib/transport/transport.h +3 -0
  533. data/src/core/load_balancing/backend_metric_parser.cc +12 -18
  534. data/src/core/load_balancing/grpclb/grpclb.cc +2 -2
  535. data/src/core/load_balancing/health_check_client.cc +2 -4
  536. data/src/core/load_balancing/oob_backend_metric.cc +2 -4
  537. data/src/core/load_balancing/outlier_detection/outlier_detection.cc +4 -3
  538. data/src/core/load_balancing/pick_first/pick_first.cc +3 -3
  539. data/src/core/load_balancing/rls/rls.cc +6 -5
  540. data/src/core/load_balancing/round_robin/round_robin.cc +2 -3
  541. data/src/core/load_balancing/weighted_round_robin/weighted_round_robin.cc +4 -4
  542. data/src/core/load_balancing/weighted_target/weighted_target.cc +3 -9
  543. data/src/core/load_balancing/xds/xds_override_host.cc +55 -34
  544. data/src/core/plugin_registry/grpc_plugin_registry.cc +2 -0
  545. data/src/core/resolver/sockaddr/sockaddr_resolver.cc +2 -1
  546. data/src/core/resolver/xds/xds_resolver.cc +2 -1
  547. data/src/core/server/add_port.cc +87 -0
  548. data/src/core/server/server.cc +48 -53
  549. data/src/core/server/server.h +3 -5
  550. data/src/core/telemetry/call_tracer.cc +2 -2
  551. data/src/core/telemetry/call_tracer.h +1 -1
  552. data/src/core/{ext/transport/chttp2/transport → telemetry}/context_list_entry.h +3 -3
  553. data/src/core/telemetry/default_tcp_tracer.cc +26 -0
  554. data/src/core/telemetry/default_tcp_tracer.h +44 -0
  555. data/src/core/telemetry/stats.h +0 -5
  556. data/src/core/telemetry/stats_data.cc +376 -334
  557. data/src/core/telemetry/stats_data.h +260 -166
  558. data/src/core/telemetry/tcp_tracer.cc +38 -0
  559. data/src/core/telemetry/tcp_tracer.h +14 -16
  560. data/src/core/transport/auth_context.cc +0 -1
  561. data/src/core/transport/auth_context.h +0 -1
  562. data/src/core/transport/endpoint_transport.h +90 -0
  563. data/src/core/transport/endpoint_transport_client_channel_factory.cc +61 -0
  564. data/src/core/transport/endpoint_transport_client_channel_factory.h +57 -0
  565. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +33 -1
  566. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +3 -1
  567. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +76 -22
  568. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +8 -2
  569. data/src/core/tsi/ssl_transport_security.cc +189 -71
  570. data/src/core/tsi/ssl_transport_security.h +6 -1
  571. data/src/core/tsi/transport_security.h +3 -0
  572. data/src/core/tsi/transport_security_grpc.h +7 -3
  573. data/src/core/tsi/transport_security_interface.h +30 -25
  574. data/src/core/util/backoff.cc +7 -14
  575. data/src/core/util/backoff.h +0 -1
  576. data/src/core/util/dual_ref_counted.h +48 -0
  577. data/src/core/util/function_signature.h +66 -0
  578. data/src/core/util/gcp_metadata_query.cc +3 -2
  579. data/src/core/util/http_client/httpcli_security_connector.cc +2 -1
  580. data/src/core/util/json/json_object_loader.h +3 -3
  581. data/src/core/util/latent_see.cc +28 -2
  582. data/src/core/util/latent_see.h +11 -23
  583. data/src/core/util/linux/env.cc +3 -1
  584. data/src/core/util/ref_counted_ptr.h +26 -0
  585. data/src/core/util/shared_bit_gen.cc +21 -0
  586. data/src/core/util/shared_bit_gen.h +44 -0
  587. data/src/core/util/single_set_ptr.h +35 -4
  588. data/src/core/util/uri.cc +75 -17
  589. data/src/core/util/uri.h +13 -8
  590. data/src/core/xds/grpc/xds_common_types_parser.cc +1 -9
  591. data/src/core/xds/grpc/xds_http_filter_registry.cc +1 -3
  592. data/src/core/xds/grpc/xds_http_rbac_filter.cc +10 -17
  593. data/src/core/xds/grpc/xds_metadata_parser.cc +40 -64
  594. data/src/core/xds/grpc/xds_metadata_parser.h +0 -2
  595. data/src/core/xds/grpc/xds_route_config_parser.cc +55 -77
  596. data/src/core/xds/xds_client/xds_client.cc +1 -1
  597. data/src/ruby/ext/grpc/extconf.rb +1 -1
  598. data/src/ruby/lib/grpc/version.rb +1 -1
  599. data/src/ruby/spec/generic/client_stub_spec.rb +2 -6
  600. data/src/ruby/spec/generic/rpc_server_spec.rb +1 -1
  601. data/third_party/abseil-cpp/absl/algorithm/algorithm.h +2 -2
  602. data/third_party/abseil-cpp/absl/algorithm/container.h +79 -48
  603. data/third_party/abseil-cpp/absl/base/attributes.h +66 -16
  604. data/third_party/abseil-cpp/absl/base/call_once.h +8 -5
  605. data/third_party/abseil-cpp/absl/base/config.h +4 -4
  606. data/third_party/abseil-cpp/absl/base/internal/nullability_impl.h +17 -56
  607. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +1 -1
  608. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +14 -0
  609. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +5 -1
  610. data/third_party/abseil-cpp/absl/base/internal/tracing.cc +39 -0
  611. data/third_party/abseil-cpp/absl/base/internal/tracing.h +81 -0
  612. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -10
  613. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +12 -0
  614. data/third_party/abseil-cpp/absl/base/macros.h +35 -4
  615. data/third_party/abseil-cpp/absl/base/nullability.h +72 -16
  616. data/third_party/abseil-cpp/absl/base/optimization.h +8 -12
  617. data/third_party/abseil-cpp/absl/base/options.h +5 -2
  618. data/third_party/abseil-cpp/absl/base/policy_checks.h +2 -0
  619. data/third_party/abseil-cpp/absl/container/btree_map.h +889 -0
  620. data/third_party/abseil-cpp/absl/container/btree_set.h +824 -0
  621. data/third_party/abseil-cpp/absl/container/fixed_array.h +2 -1
  622. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +17 -3
  623. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +17 -3
  624. data/third_party/abseil-cpp/absl/container/inlined_vector.h +2 -1
  625. data/third_party/abseil-cpp/absl/container/internal/btree.h +3046 -0
  626. data/third_party/abseil-cpp/absl/container/internal/btree_container.h +763 -0
  627. data/third_party/abseil-cpp/absl/container/internal/common_policy_traits.h +9 -0
  628. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +1 -0
  629. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +4 -2
  630. data/third_party/abseil-cpp/absl/container/internal/layout.h +1 -1
  631. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +142 -114
  632. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +397 -231
  633. data/third_party/abseil-cpp/absl/crc/internal/cpu_detect.cc +56 -0
  634. data/third_party/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +21 -7
  635. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +4 -2
  636. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +1 -1
  637. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +17 -1
  638. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +7 -0
  639. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +9 -6
  640. data/third_party/abseil-cpp/absl/debugging/leak_check.cc +73 -0
  641. data/third_party/abseil-cpp/absl/debugging/leak_check.h +150 -0
  642. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +3 -2
  643. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +48 -9
  644. data/third_party/abseil-cpp/absl/flags/commandlineflag.cc +1 -0
  645. data/third_party/abseil-cpp/absl/flags/commandlineflag.h +7 -0
  646. data/third_party/abseil-cpp/absl/flags/flag.h +14 -12
  647. data/third_party/abseil-cpp/absl/flags/internal/flag.cc +12 -4
  648. data/third_party/abseil-cpp/absl/flags/internal/flag.h +16 -5
  649. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +4 -0
  650. data/third_party/abseil-cpp/absl/flags/internal/private_handle_accessor.h +3 -0
  651. data/third_party/abseil-cpp/absl/flags/internal/program_name.cc +13 -12
  652. data/third_party/abseil-cpp/absl/flags/usage_config.cc +9 -4
  653. data/third_party/abseil-cpp/absl/hash/hash.h +26 -2
  654. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +17 -17
  655. data/third_party/abseil-cpp/absl/hash/internal/hash.h +196 -91
  656. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +2 -4
  657. data/third_party/abseil-cpp/absl/log/absl_vlog_is_on.h +2 -0
  658. data/third_party/abseil-cpp/absl/log/internal/check_op.cc +27 -22
  659. data/third_party/abseil-cpp/absl/log/internal/check_op.h +102 -80
  660. data/third_party/abseil-cpp/absl/log/internal/log_message.cc +90 -38
  661. data/third_party/abseil-cpp/absl/log/internal/log_message.h +80 -48
  662. data/third_party/abseil-cpp/absl/log/internal/proto.cc +0 -3
  663. data/third_party/abseil-cpp/absl/log/internal/proto.h +25 -15
  664. data/third_party/abseil-cpp/absl/log/internal/structured_proto.cc +115 -0
  665. data/third_party/abseil-cpp/absl/log/internal/structured_proto.h +107 -0
  666. data/third_party/abseil-cpp/absl/log/internal/vlog_config.cc +8 -1
  667. data/third_party/abseil-cpp/absl/log/log_sink_registry.h +5 -2
  668. data/third_party/abseil-cpp/absl/log/vlog_is_on.h +2 -0
  669. data/third_party/abseil-cpp/absl/meta/type_traits.h +16 -6
  670. data/third_party/abseil-cpp/absl/numeric/int128.h +15 -3
  671. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +6 -4
  672. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +6 -3
  673. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +3 -1
  674. data/third_party/abseil-cpp/absl/random/beta_distribution.h +3 -1
  675. data/third_party/abseil-cpp/absl/random/bit_gen_ref.h +2 -1
  676. data/third_party/abseil-cpp/absl/random/discrete_distribution.cc +10 -0
  677. data/third_party/abseil-cpp/absl/random/discrete_distribution.h +4 -2
  678. data/third_party/abseil-cpp/absl/random/exponential_distribution.h +1 -0
  679. data/third_party/abseil-cpp/absl/random/gaussian_distribution.h +2 -1
  680. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +3 -1
  681. data/third_party/abseil-cpp/absl/random/internal/iostream_state_saver.h +5 -2
  682. data/third_party/abseil-cpp/absl/random/internal/platform.h +12 -12
  683. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +56 -5
  684. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +2 -1
  685. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +2 -2
  686. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +0 -1
  687. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +1 -4
  688. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +4 -3
  689. data/third_party/abseil-cpp/absl/random/seed_gen_exception.cc +2 -3
  690. data/third_party/abseil-cpp/absl/random/seed_sequences.h +1 -2
  691. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +2 -1
  692. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +2 -0
  693. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +5 -4
  694. data/third_party/abseil-cpp/absl/status/internal/status_internal.cc +8 -4
  695. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +1 -1
  696. data/third_party/abseil-cpp/absl/status/status.h +1 -1
  697. data/third_party/abseil-cpp/absl/strings/ascii.cc +41 -26
  698. data/third_party/abseil-cpp/absl/strings/ascii.h +48 -8
  699. data/third_party/abseil-cpp/absl/strings/charconv.cc +4 -7
  700. data/third_party/abseil-cpp/absl/strings/charset.h +3 -4
  701. data/third_party/abseil-cpp/absl/strings/cord.h +5 -19
  702. data/third_party/abseil-cpp/absl/strings/escaping.cc +56 -48
  703. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +1 -1
  704. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +48 -15
  705. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +3 -2
  706. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +35 -0
  707. data/third_party/abseil-cpp/absl/strings/match.h +21 -11
  708. data/third_party/abseil-cpp/absl/strings/numbers.cc +2 -1
  709. data/third_party/abseil-cpp/absl/strings/str_cat.h +11 -0
  710. data/third_party/abseil-cpp/absl/strings/str_split.h +18 -1
  711. data/third_party/abseil-cpp/absl/strings/string_view.h +20 -19
  712. data/third_party/abseil-cpp/absl/strings/strip.h +11 -8
  713. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +16 -10
  714. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +6 -0
  715. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +5 -1
  716. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +38 -12
  717. data/third_party/abseil-cpp/absl/synchronization/notification.cc +10 -2
  718. data/third_party/abseil-cpp/absl/synchronization/notification.h +11 -1
  719. data/third_party/abseil-cpp/absl/time/duration.cc +6 -51
  720. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +1 -1
  721. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +1 -1
  722. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +3 -3
  723. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +2 -2
  724. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +2 -2
  725. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +3 -3
  726. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +2 -2
  727. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +1 -1
  728. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +1 -1
  729. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +3 -2
  730. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +1 -1
  731. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +6 -4
  732. data/third_party/abseil-cpp/absl/time/time.h +84 -23
  733. data/third_party/abseil-cpp/absl/types/internal/span.h +3 -2
  734. data/third_party/abseil-cpp/absl/types/optional.h +4 -2
  735. data/third_party/abseil-cpp/absl/types/span.h +85 -43
  736. data/third_party/boringssl-with-bazel/src/crypto/aes/aes.cc +41 -0
  737. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.cc +16 -0
  738. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.cc +15 -0
  739. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +19 -3
  740. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.cc +79 -48
  741. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.cc +11 -19
  742. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.cc +3 -7
  743. data/third_party/boringssl-with-bazel/src/crypto/bcm_support.h +0 -35
  744. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.cc +0 -2
  745. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +3 -5
  746. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.cc +0 -3
  747. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.cc +0 -2
  748. data/third_party/boringssl-with-bazel/src/crypto/bn/convert.cc +31 -47
  749. data/third_party/boringssl-with-bazel/src/crypto/bn/div.cc +100 -0
  750. data/third_party/boringssl-with-bazel/src/crypto/bn/exponentiation.cc +166 -0
  751. data/third_party/boringssl-with-bazel/src/crypto/bn/sqrt.cc +93 -0
  752. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.cc +14 -8
  753. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.cc +1 -1
  754. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +3 -3
  755. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +4 -4
  756. data/third_party/boringssl-with-bazel/src/crypto/cipher/derive_key.cc +13 -15
  757. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aeseax.cc +289 -0
  758. data/third_party/boringssl-with-bazel/src/crypto/cipher/e_aesgcmsiv.cc +179 -102
  759. data/third_party/boringssl-with-bazel/src/crypto/cipher/internal.h +3 -3
  760. data/third_party/boringssl-with-bazel/src/crypto/cms/cms.cc +172 -0
  761. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.cc +28 -5
  762. data/third_party/boringssl-with-bazel/src/crypto/cpu_arm_linux.h +11 -9
  763. data/third_party/boringssl-with-bazel/src/crypto/cpu_intel.cc +0 -6
  764. data/third_party/boringssl-with-bazel/src/crypto/crypto.cc +1 -1
  765. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +3 -3
  766. data/third_party/boringssl-with-bazel/src/crypto/des/internal.h +3 -3
  767. data/third_party/boringssl-with-bazel/src/crypto/dh/dh_asn1.cc +13 -14
  768. data/third_party/boringssl-with-bazel/src/crypto/dh/params.cc +27 -61
  769. data/third_party/boringssl-with-bazel/src/crypto/digest/digest_extra.cc +16 -8
  770. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.cc +112 -122
  771. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.cc +23 -35
  772. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +3 -3
  773. data/third_party/boringssl-with-bazel/src/crypto/ec/ec_asn1.cc +47 -63
  774. data/third_party/boringssl-with-bazel/src/crypto/ec/hash_to_curve.cc +60 -68
  775. data/third_party/boringssl-with-bazel/src/crypto/ec/internal.h +3 -3
  776. data/third_party/boringssl-with-bazel/src/crypto/ecdsa/ecdsa_asn1.cc +11 -17
  777. data/third_party/boringssl-with-bazel/src/crypto/err/err.cc +0 -2
  778. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.cc +10 -11
  779. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.cc +10 -11
  780. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +3 -3
  781. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.cc +6 -6
  782. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.cc +6 -6
  783. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.cc +6 -6
  784. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.cc +6 -6
  785. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.cc +6 -6
  786. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.cc +23 -42
  787. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.cc.inc +29 -18
  788. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/gcm.cc.inc +10 -10
  789. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +16 -45
  790. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.cc.inc +5 -4
  791. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.cc.inc +15 -6
  792. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.cc +3 -3
  793. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm_interface.h +101 -5
  794. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.cc.inc +96 -187
  795. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.cc.inc +24 -512
  796. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.cc.inc +58 -80
  797. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.cc.inc +29 -45
  798. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +27 -25
  799. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.cc.inc +7 -16
  800. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.cc.inc +27 -48
  801. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.cc.inc +34 -34
  802. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.cc.inc +102 -154
  803. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +3 -3
  804. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.cc.inc +3 -8
  805. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.cc.inc +1 -78
  806. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.cc.inc +10 -17
  807. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +3 -3
  808. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +15 -8
  809. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.cc.inc +40 -53
  810. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.cc.inc +57 -76
  811. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.cc.inc +4 -10
  812. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/internal.h +3 -3
  813. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +3 -3
  814. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.cc.inc +37 -52
  815. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.cc.inc +13 -20
  816. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +3 -3
  817. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.cc.inc +28 -39
  818. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-nistz.h +3 -3
  819. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.cc.inc +6 -11
  820. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/keccak/internal.h +3 -3
  821. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mldsa/fips_known_values.inc +1345 -0
  822. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mldsa/mldsa.cc.inc +335 -28
  823. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mlkem/fips_known_values.inc +411 -0
  824. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/mlkem/mlkem.cc.inc +265 -33
  825. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +3 -3
  826. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.cc.inc +1 -1
  827. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +3 -3
  828. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.cc.inc +19 -26
  829. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.cc.inc +7 -7
  830. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.cc.inc +121 -138
  831. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.cc.inc +96 -83
  832. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/service_indicator/internal.h +3 -3
  833. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +8 -20
  834. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/fips_known_values.inc +674 -0
  835. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/slhdsa/slhdsa.cc.inc +235 -60
  836. data/third_party/boringssl-with-bazel/src/crypto/fuzzer_mode.cc +30 -0
  837. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +3 -3
  838. data/third_party/boringssl-with-bazel/src/crypto/internal.h +39 -30
  839. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +3 -3
  840. data/third_party/boringssl-with-bazel/src/crypto/md5/internal.h +3 -3
  841. data/third_party/boringssl-with-bazel/src/crypto/mem.cc +0 -2
  842. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.cc +2 -8
  843. data/third_party/boringssl-with-bazel/src/crypto/pem/internal.h +3 -3
  844. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.cc +8 -13
  845. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +22 -8
  846. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.cc +19 -17
  847. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.cc +134 -136
  848. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +14 -8
  849. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.cc +25 -21
  850. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.cc +36 -52
  851. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.cc +97 -79
  852. data/third_party/boringssl-with-bazel/src/crypto/poly1305/internal.h +3 -3
  853. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +3 -3
  854. data/third_party/boringssl-with-bazel/src/crypto/rand/deterministic.cc +1 -1
  855. data/third_party/boringssl-with-bazel/src/crypto/rand/fork_detect.cc +2 -2
  856. data/third_party/boringssl-with-bazel/src/crypto/rand/getentropy.cc +1 -1
  857. data/third_party/boringssl-with-bazel/src/crypto/rand/{sysrand_internal.h → internal.h} +22 -4
  858. data/third_party/boringssl-with-bazel/src/crypto/rand/ios.cc +1 -1
  859. data/third_party/boringssl-with-bazel/src/crypto/rand/trusty.cc +1 -1
  860. data/third_party/boringssl-with-bazel/src/crypto/rand/urandom.cc +1 -1
  861. data/third_party/boringssl-with-bazel/src/crypto/rand/windows.cc +1 -5
  862. data/third_party/boringssl-with-bazel/src/crypto/rsa/internal.h +3 -3
  863. data/third_party/boringssl-with-bazel/src/crypto/rsa/rsa_crypt.cc +14 -22
  864. data/third_party/boringssl-with-bazel/src/crypto/spake2plus/internal.h +3 -3
  865. data/third_party/boringssl-with-bazel/src/crypto/thread_win.cc +0 -2
  866. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +3 -3
  867. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.cc +3 -5
  868. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.cc +8 -12
  869. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +15 -3
  870. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_conf.cc +16 -24
  871. data/third_party/boringssl-with-bazel/src/crypto/x509/v3_info.cc +18 -21
  872. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.cc +10 -3
  873. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.cc +9 -0
  874. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.cc +10 -1
  875. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.cc +64 -85
  876. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.cc +16 -32
  877. data/third_party/boringssl-with-bazel/src/gen/crypto/err_data.cc +576 -567
  878. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +16 -8
  879. data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +1 -1
  880. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +6 -54
  881. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +1 -1
  882. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +8 -4
  883. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +1 -1
  884. data/third_party/boringssl-with-bazel/src/include/openssl/bcm_public.h +1 -1
  885. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +1 -1
  886. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +1 -1
  887. data/third_party/boringssl-with-bazel/src/include/openssl/blowfish.h +1 -1
  888. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +1 -1
  889. data/third_party/boringssl-with-bazel/src/include/openssl/buf.h +1 -1
  890. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +7 -1
  891. data/third_party/boringssl-with-bazel/src/include/openssl/cast.h +1 -1
  892. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +1 -1
  893. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +1 -1
  894. data/third_party/boringssl-with-bazel/src/include/openssl/cmac.h +1 -1
  895. data/third_party/boringssl-with-bazel/src/include/openssl/cms.h +146 -0
  896. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +1 -1
  897. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +23 -3
  898. data/third_party/boringssl-with-bazel/src/include/openssl/ctrdrbg.h +1 -1
  899. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +1 -1
  900. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +1 -1
  901. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +1 -1
  902. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +19 -7
  903. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +1 -1
  904. data/third_party/boringssl-with-bazel/src/include/openssl/e_os2.h +1 -1
  905. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +1 -1
  906. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +1 -1
  907. data/third_party/boringssl-with-bazel/src/include/openssl/ecdh.h +1 -1
  908. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +1 -1
  909. data/third_party/boringssl-with-bazel/src/include/openssl/engine.h +1 -1
  910. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +2 -1
  911. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +1 -1
  912. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +1 -1
  913. data/third_party/boringssl-with-bazel/src/include/openssl/experimental/kyber.h +1 -1
  914. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +1 -1
  915. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +1 -1
  916. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +4 -4
  917. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +1 -1
  918. data/third_party/boringssl-with-bazel/src/include/openssl/kdf.h +1 -1
  919. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +1 -1
  920. data/third_party/boringssl-with-bazel/src/include/openssl/md4.h +1 -1
  921. data/third_party/boringssl-with-bazel/src/include/openssl/md5.h +1 -1
  922. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +1 -1
  923. data/third_party/boringssl-with-bazel/src/include/openssl/mldsa.h +1 -1
  924. data/third_party/boringssl-with-bazel/src/include/openssl/mlkem.h +1 -1
  925. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +1 -1
  926. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +1 -1
  927. data/third_party/boringssl-with-bazel/src/include/openssl/obj_mac.h +1 -1
  928. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +10 -4
  929. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +1 -1
  930. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +19 -6
  931. data/third_party/boringssl-with-bazel/src/include/openssl/poly1305.h +1 -1
  932. data/third_party/boringssl-with-bazel/src/include/openssl/pool.h +1 -1
  933. data/third_party/boringssl-with-bazel/src/include/openssl/posix_time.h +1 -1
  934. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +2 -2
  935. data/third_party/boringssl-with-bazel/src/include/openssl/rc4.h +1 -1
  936. data/third_party/boringssl-with-bazel/src/include/openssl/ripemd.h +1 -1
  937. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +2 -2
  938. data/third_party/boringssl-with-bazel/src/include/openssl/service_indicator.h +1 -1
  939. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +1 -1
  940. data/third_party/boringssl-with-bazel/src/include/openssl/siphash.h +1 -1
  941. data/third_party/boringssl-with-bazel/src/include/openssl/slhdsa.h +1 -1
  942. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +1 -1
  943. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +291 -40
  944. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +1 -1
  945. data/third_party/boringssl-with-bazel/src/include/openssl/target.h +0 -5
  946. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +1 -1
  947. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +9 -1
  948. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +1 -1
  949. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +1 -1
  950. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +7 -4
  951. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +2 -0
  952. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +32 -26
  953. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +49 -49
  954. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +253 -50
  955. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +12 -12
  956. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +7 -5
  957. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +2 -1
  958. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +24 -32
  959. data/third_party/boringssl-with-bazel/src/ssl/internal.h +93 -4
  960. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +6 -12
  961. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +18 -4
  962. data/third_party/boringssl-with-bazel/src/ssl/ssl_credential.cc +83 -7
  963. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +1 -1
  964. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +173 -19
  965. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +5 -18
  966. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +28 -15
  967. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +1 -1
  968. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +31 -7
  969. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +13 -1
  970. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +7 -11
  971. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +13 -11
  972. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +2 -5
  973. data/third_party/upb/upb/hash/common.c +310 -189
  974. data/third_party/upb/upb/hash/common.h +44 -43
  975. data/third_party/upb/upb/hash/int_table.h +29 -5
  976. data/third_party/upb/upb/hash/str_table.h +6 -0
  977. data/third_party/upb/upb/mem/arena.c +180 -57
  978. data/third_party/upb/upb/mem/arena.h +10 -0
  979. data/third_party/upb/upb/mem/internal/arena.h +62 -24
  980. data/third_party/upb/upb/message/accessors.c +1 -5
  981. data/third_party/upb/upb/message/array.c +7 -6
  982. data/third_party/upb/upb/message/array.h +4 -4
  983. data/third_party/upb/upb/message/internal/accessors.h +3 -3
  984. data/third_party/upb/upb/message/internal/extension.c +0 -12
  985. data/third_party/upb/upb/message/internal/extension.h +0 -4
  986. data/third_party/upb/upb/message/internal/iterator.h +3 -3
  987. data/third_party/upb/upb/message/internal/map.h +75 -20
  988. data/third_party/upb/upb/message/internal/map_sorter.h +10 -2
  989. data/third_party/upb/upb/message/internal/message.h +53 -5
  990. data/third_party/upb/upb/message/map.c +68 -20
  991. data/third_party/upb/upb/message/map.h +8 -1
  992. data/third_party/upb/upb/message/map_gencode_util.h +3 -45
  993. data/third_party/upb/upb/message/map_sorter.c +32 -8
  994. data/third_party/upb/upb/message/merge.h +3 -3
  995. data/third_party/upb/upb/message/message.c +120 -14
  996. data/third_party/upb/upb/message/message.h +17 -8
  997. data/third_party/upb/upb/mini_descriptor/build_enum.c +15 -5
  998. data/third_party/upb/upb/mini_descriptor/decode.c +18 -2
  999. data/third_party/upb/upb/mini_descriptor/link.c +4 -0
  1000. data/third_party/upb/upb/mini_table/extension.h +8 -1
  1001. data/third_party/upb/upb/mini_table/extension_registry.c +1 -1
  1002. data/third_party/upb/upb/mini_table/internal/enum.h +1 -1
  1003. data/third_party/upb/upb/mini_table/internal/extension.h +24 -1
  1004. data/third_party/upb/upb/mini_table/internal/field.h +4 -4
  1005. data/third_party/upb/upb/mini_table/internal/message.h +1 -1
  1006. data/third_party/upb/upb/port/def.inc +32 -16
  1007. data/third_party/upb/upb/port/undef.inc +1 -0
  1008. data/third_party/upb/upb/reflection/def_pool.h +2 -2
  1009. data/third_party/upb/upb/reflection/descriptor_bootstrap.h +3 -3
  1010. data/third_party/upb/upb/reflection/enum_def.c +4 -4
  1011. data/third_party/upb/upb/reflection/enum_reserved_range.c +1 -1
  1012. data/third_party/upb/upb/reflection/enum_value_def.c +9 -8
  1013. data/third_party/upb/upb/reflection/extension_range.c +1 -2
  1014. data/third_party/upb/upb/reflection/field_def.c +3 -5
  1015. data/third_party/upb/upb/reflection/field_def.h +1 -1
  1016. data/third_party/upb/upb/reflection/file_def.c +4 -5
  1017. data/third_party/upb/upb/reflection/internal/def_builder.h +35 -10
  1018. data/third_party/upb/upb/reflection/internal/enum_value_def.h +1 -1
  1019. data/third_party/upb/upb/reflection/internal/upb_edition_defaults.h +1 -1
  1020. data/third_party/upb/upb/reflection/message_def.c +4 -7
  1021. data/third_party/upb/upb/reflection/message_reserved_range.c +1 -1
  1022. data/third_party/upb/upb/reflection/method_def.c +1 -1
  1023. data/third_party/upb/upb/reflection/oneof_def.c +3 -3
  1024. data/third_party/upb/upb/reflection/service_def.c +2 -5
  1025. data/third_party/upb/upb/text/encode.c +16 -0
  1026. data/third_party/upb/upb/text/internal/encode.h +2 -1
  1027. data/third_party/upb/upb/wire/decode.c +104 -72
  1028. data/third_party/upb/upb/wire/encode.c +37 -13
  1029. data/third_party/upb/upb/wire/internal/decode_fast.c +2 -2
  1030. data/third_party/upb/upb/wire/internal/decode_fast.h +4 -0
  1031. metadata +43 -7
  1032. data/src/core/lib/iomgr/executor.cc +0 -441
  1033. data/src/core/lib/iomgr/executor.h +0 -119
  1034. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/polyval.cc.inc +0 -89
@@ -121,849 +121,6 @@ Timestamp GetConnectionDeadline(const ChannelArgs& args) {
121
121
 
122
122
  using AcceptorPtr = std::unique_ptr<grpc_tcp_server_acceptor, AcceptorDeleter>;
123
123
 
124
- class Chttp2ServerListener : public Server::ListenerInterface {
125
- public:
126
- static grpc_error_handle Create(Server* server,
127
- const EventEngine::ResolvedAddress& addr,
128
- const ChannelArgs& args, int* port_num);
129
-
130
- static grpc_error_handle CreateWithAcceptor(Server* server, const char* name,
131
- const ChannelArgs& args);
132
-
133
- static Chttp2ServerListener* CreateForPassiveListener(
134
- Server* server, const ChannelArgs& args,
135
- std::shared_ptr<experimental::PassiveListenerImpl> passive_listener);
136
-
137
- // Do not instantiate directly. Use one of the factory methods above.
138
- Chttp2ServerListener(Server* server, const ChannelArgs& args,
139
- ServerConfigFetcher* config_fetcher,
140
- std::shared_ptr<experimental::PassiveListenerImpl>
141
- passive_listener = nullptr);
142
- ~Chttp2ServerListener() override;
143
-
144
- void Start() override;
145
-
146
- void AcceptConnectedEndpoint(std::unique_ptr<EventEngine::Endpoint> endpoint);
147
-
148
- channelz::ListenSocketNode* channelz_listen_socket_node() const override {
149
- return channelz_listen_socket_.get();
150
- }
151
-
152
- void SetServerListenerState(
153
- RefCountedPtr<Server::ListenerState> /*listener_state*/) override {}
154
-
155
- const grpc_resolved_address* resolved_address() const override {
156
- // Should only be invoked with experiment server_listener
157
- Crash("Illegal");
158
- return nullptr;
159
- }
160
-
161
- void SetOnDestroyDone(grpc_closure* on_destroy_done) override;
162
-
163
- void Orphan() override;
164
-
165
- private:
166
- friend class experimental::PassiveListenerImpl;
167
-
168
- class ConfigFetcherWatcher : public ServerConfigFetcher::WatcherInterface {
169
- public:
170
- explicit ConfigFetcherWatcher(RefCountedPtr<Chttp2ServerListener> listener)
171
- : listener_(std::move(listener)) {}
172
-
173
- void UpdateConnectionManager(
174
- RefCountedPtr<ServerConfigFetcher::ConnectionManager>
175
- connection_manager) override;
176
-
177
- void StopServing() override;
178
-
179
- private:
180
- RefCountedPtr<Chttp2ServerListener> listener_;
181
- };
182
-
183
- class ActiveConnection : public InternallyRefCounted<ActiveConnection> {
184
- public:
185
- class HandshakingState : public InternallyRefCounted<HandshakingState> {
186
- public:
187
- HandshakingState(RefCountedPtr<ActiveConnection> connection_ref,
188
- grpc_pollset* accepting_pollset, AcceptorPtr acceptor,
189
- const ChannelArgs& args);
190
-
191
- ~HandshakingState() override;
192
-
193
- void Orphan() override;
194
-
195
- void Start(OrphanablePtr<grpc_endpoint> endpoint,
196
- const ChannelArgs& args);
197
-
198
- void ShutdownLocked(absl::Status status)
199
- ABSL_EXCLUSIVE_LOCKS_REQUIRED(&ActiveConnection::mu_);
200
-
201
- // Needed to be able to grab an external ref in
202
- // ActiveConnection::Start()
203
- using InternallyRefCounted<HandshakingState>::Ref;
204
-
205
- private:
206
- void OnTimeout() ABSL_LOCKS_EXCLUDED(&ActiveConnection::mu_);
207
- static void OnReceiveSettings(void* arg, grpc_error_handle /* error */);
208
- void OnHandshakeDone(absl::StatusOr<HandshakerArgs*> result);
209
- RefCountedPtr<ActiveConnection> const connection_;
210
- grpc_pollset* const accepting_pollset_;
211
- AcceptorPtr acceptor_;
212
- RefCountedPtr<HandshakeManager> handshake_mgr_
213
- ABSL_GUARDED_BY(&ActiveConnection::mu_);
214
- // State for enforcing handshake timeout on receiving HTTP/2 settings.
215
- Timestamp const deadline_;
216
- std::optional<EventEngine::TaskHandle> timer_handle_
217
- ABSL_GUARDED_BY(&ActiveConnection::mu_);
218
- grpc_closure on_receive_settings_ ABSL_GUARDED_BY(&ActiveConnection::mu_);
219
- grpc_pollset_set* const interested_parties_;
220
- };
221
-
222
- ActiveConnection(RefCountedPtr<Chttp2ServerListener> listener,
223
- grpc_pollset* accepting_pollset, AcceptorPtr acceptor,
224
- EventEngine* event_engine, const ChannelArgs& args,
225
- MemoryOwner memory_owner);
226
-
227
- void Orphan() override;
228
-
229
- void SendGoAway();
230
-
231
- void Start(OrphanablePtr<grpc_endpoint> endpoint, const ChannelArgs& args);
232
-
233
- // Needed to be able to grab an external ref in
234
- // Chttp2ServerListener::OnAccept()
235
- using InternallyRefCounted<ActiveConnection>::Ref;
236
-
237
- private:
238
- static void OnClose(void* arg, grpc_error_handle error);
239
- void OnDrainGraceTimeExpiry() ABSL_LOCKS_EXCLUDED(&mu_);
240
-
241
- RefCountedPtr<Chttp2ServerListener> listener_;
242
- Mutex mu_ ABSL_ACQUIRED_AFTER(&listener_->mu_);
243
- // Was ActiveConnection::Start() invoked? Used to determine whether
244
- // tcp_server needs to be unreffed.
245
- bool connection_started_ ABSL_GUARDED_BY(&mu_) = false;
246
- // Set by HandshakingState before the handshaking begins and reset when
247
- // handshaking is done.
248
- OrphanablePtr<HandshakingState> handshaking_state_ ABSL_GUARDED_BY(&mu_);
249
- // Set by HandshakingState when handshaking is done and a valid transport
250
- // is created.
251
- RefCountedPtr<grpc_chttp2_transport> transport_ ABSL_GUARDED_BY(&mu_) =
252
- nullptr;
253
- grpc_closure on_close_;
254
- std::optional<EventEngine::TaskHandle> drain_grace_timer_handle_
255
- ABSL_GUARDED_BY(&mu_);
256
- // Use a raw pointer since this event_engine_ is grabbed from the
257
- // ChannelArgs of the listener_.
258
- EventEngine* const event_engine_ ABSL_GUARDED_BY(&mu_);
259
- bool shutdown_ ABSL_GUARDED_BY(&mu_) = false;
260
- };
261
-
262
- // To allow access to RefCounted<> like interface.
263
- friend class RefCountedPtr<Chttp2ServerListener>;
264
-
265
- // Should only be called once so as to start the TCP server.
266
- void StartListening();
267
-
268
- static void OnAccept(void* arg, grpc_endpoint* tcp,
269
- grpc_pollset* accepting_pollset,
270
- grpc_tcp_server_acceptor* acceptor);
271
-
272
- static void TcpServerShutdownComplete(void* arg, grpc_error_handle error);
273
-
274
- static void DestroyListener(Server* /*server*/, void* arg,
275
- grpc_closure* destroy_done);
276
-
277
- Server* const server_ = nullptr;
278
- grpc_tcp_server* tcp_server_ = nullptr;
279
- grpc_resolved_address resolved_address_;
280
- ConfigFetcherWatcher* config_fetcher_watcher_ = nullptr;
281
- ChannelArgs args_;
282
- Mutex mu_;
283
- RefCountedPtr<ServerConfigFetcher::ConnectionManager> connection_manager_
284
- ABSL_GUARDED_BY(mu_);
285
- // Signals whether grpc_tcp_server_start() has been called.
286
- bool started_ ABSL_GUARDED_BY(mu_) = false;
287
- // Signals whether grpc_tcp_server_start() has completed.
288
- CondVar started_cv_ ABSL_GUARDED_BY(mu_);
289
- // Signals whether new requests/connections are to be accepted.
290
- bool is_serving_ ABSL_GUARDED_BY(mu_) = false;
291
- // Signals whether the application has triggered shutdown.
292
- bool shutdown_ ABSL_GUARDED_BY(mu_) = false;
293
- std::map<ActiveConnection*, OrphanablePtr<ActiveConnection>> connections_
294
- ABSL_GUARDED_BY(mu_);
295
- grpc_closure tcp_server_shutdown_complete_ ABSL_GUARDED_BY(mu_);
296
- grpc_closure* on_destroy_done_ ABSL_GUARDED_BY(mu_) = nullptr;
297
- RefCountedPtr<channelz::ListenSocketNode> channelz_listen_socket_;
298
- MemoryQuotaRefPtr memory_quota_;
299
- ConnectionQuotaRefPtr connection_quota_;
300
- ServerConfigFetcher* config_fetcher_ = nullptr;
301
- // TODO(yashykt): consider using std::variant<> to minimize memory usage for
302
- // disjoint cases where different fields are used.
303
- std::shared_ptr<experimental::PassiveListenerImpl> passive_listener_;
304
- };
305
-
306
- //
307
- // Chttp2ServerListener::ConfigFetcherWatcher
308
- //
309
-
310
- void Chttp2ServerListener::ConfigFetcherWatcher::UpdateConnectionManager(
311
- RefCountedPtr<ServerConfigFetcher::ConnectionManager> connection_manager) {
312
- RefCountedPtr<ServerConfigFetcher::ConnectionManager>
313
- connection_manager_to_destroy;
314
- class GracefulShutdownExistingConnections {
315
- public:
316
- ~GracefulShutdownExistingConnections() {
317
- // Send GOAWAYs on the transports so that they get disconnected when
318
- // existing RPCs finish, and so that no new RPC is started on them.
319
- for (auto& connection : connections_) {
320
- connection.first->SendGoAway();
321
- }
322
- }
323
-
324
- void set_connections(
325
- std::map<ActiveConnection*, OrphanablePtr<ActiveConnection>>
326
- connections) {
327
- CHECK(connections_.empty());
328
- connections_ = std::move(connections);
329
- }
330
-
331
- private:
332
- std::map<ActiveConnection*, OrphanablePtr<ActiveConnection>> connections_;
333
- } connections_to_shutdown;
334
- {
335
- MutexLock lock(&listener_->mu_);
336
- connection_manager_to_destroy = listener_->connection_manager_;
337
- listener_->connection_manager_ = std::move(connection_manager);
338
- connections_to_shutdown.set_connections(std::move(listener_->connections_));
339
- if (listener_->shutdown_) {
340
- return;
341
- }
342
- listener_->is_serving_ = true;
343
- if (listener_->started_) return;
344
- }
345
- int port_temp;
346
- grpc_error_handle error = grpc_tcp_server_add_port(
347
- listener_->tcp_server_, &listener_->resolved_address_, &port_temp);
348
- if (!error.ok()) {
349
- LOG(ERROR) << "Error adding port to server: " << StatusToString(error);
350
- // TODO(yashykt): We wouldn't need to assert here if we bound to the
351
- // port earlier during AddPort.
352
- CHECK(0);
353
- }
354
- listener_->StartListening();
355
- {
356
- MutexLock lock(&listener_->mu_);
357
- listener_->started_ = true;
358
- listener_->started_cv_.SignalAll();
359
- }
360
- }
361
-
362
- void Chttp2ServerListener::ConfigFetcherWatcher::StopServing() {
363
- std::map<ActiveConnection*, OrphanablePtr<ActiveConnection>> connections;
364
- {
365
- MutexLock lock(&listener_->mu_);
366
- listener_->is_serving_ = false;
367
- connections = std::move(listener_->connections_);
368
- }
369
- // Send GOAWAYs on the transports so that they disconnected when existing
370
- // RPCs finish.
371
- for (auto& connection : connections) {
372
- connection.first->SendGoAway();
373
- }
374
- }
375
-
376
- //
377
- // Chttp2ServerListener::ActiveConnection::HandshakingState
378
- //
379
-
380
- Chttp2ServerListener::ActiveConnection::HandshakingState::HandshakingState(
381
- RefCountedPtr<ActiveConnection> connection_ref,
382
- grpc_pollset* accepting_pollset, AcceptorPtr acceptor,
383
- const ChannelArgs& args)
384
- : connection_(std::move(connection_ref)),
385
- accepting_pollset_(accepting_pollset),
386
- acceptor_(std::move(acceptor)),
387
- handshake_mgr_(MakeRefCounted<HandshakeManager>()),
388
- deadline_(GetConnectionDeadline(args)),
389
- interested_parties_(grpc_pollset_set_create()) {
390
- if (accepting_pollset != nullptr) {
391
- grpc_pollset_set_add_pollset(interested_parties_, accepting_pollset_);
392
- }
393
- CoreConfiguration::Get().handshaker_registry().AddHandshakers(
394
- HANDSHAKER_SERVER, args, interested_parties_, handshake_mgr_.get());
395
- }
396
-
397
- Chttp2ServerListener::ActiveConnection::HandshakingState::~HandshakingState() {
398
- bool connection_started = false;
399
- {
400
- MutexLock lock(&connection_->mu_);
401
- connection_started = connection_->connection_started_;
402
- }
403
- if (accepting_pollset_ != nullptr) {
404
- grpc_pollset_set_del_pollset(interested_parties_, accepting_pollset_);
405
- }
406
- grpc_pollset_set_destroy(interested_parties_);
407
- if (connection_started && connection_->listener_ != nullptr &&
408
- connection_->listener_->tcp_server_ != nullptr) {
409
- grpc_tcp_server_unref(connection_->listener_->tcp_server_);
410
- }
411
- }
412
-
413
- void Chttp2ServerListener::ActiveConnection::HandshakingState::Orphan() {
414
- {
415
- MutexLock lock(&connection_->mu_);
416
- ShutdownLocked(absl::UnavailableError("Listener stopped serving."));
417
- }
418
- Unref();
419
- }
420
-
421
- void Chttp2ServerListener::ActiveConnection::HandshakingState::Start(
422
- OrphanablePtr<grpc_endpoint> endpoint, const ChannelArgs& channel_args) {
423
- RefCountedPtr<HandshakeManager> handshake_mgr;
424
- {
425
- MutexLock lock(&connection_->mu_);
426
- if (handshake_mgr_ == nullptr) return;
427
- handshake_mgr = handshake_mgr_;
428
- }
429
- handshake_mgr->DoHandshake(
430
- std::move(endpoint), channel_args, deadline_, acceptor_.get(),
431
- [self = Ref()](absl::StatusOr<HandshakerArgs*> result) {
432
- self->OnHandshakeDone(std::move(result));
433
- });
434
- }
435
-
436
- void Chttp2ServerListener::ActiveConnection::HandshakingState::ShutdownLocked(
437
- absl::Status status) {
438
- if (handshake_mgr_ != nullptr) {
439
- handshake_mgr_->Shutdown(std::move(status));
440
- }
441
- }
442
-
443
- void Chttp2ServerListener::ActiveConnection::HandshakingState::OnTimeout() {
444
- grpc_chttp2_transport* transport = nullptr;
445
- {
446
- MutexLock lock(&connection_->mu_);
447
- if (timer_handle_.has_value()) {
448
- transport = connection_->transport_.get();
449
- timer_handle_.reset();
450
- }
451
- }
452
- if (transport != nullptr) {
453
- grpc_transport_op* op = grpc_make_transport_op(nullptr);
454
- op->disconnect_with_error = GRPC_ERROR_CREATE(
455
- "Did not receive HTTP/2 settings before handshake timeout");
456
- transport->PerformOp(op);
457
- }
458
- }
459
-
460
- void Chttp2ServerListener::ActiveConnection::HandshakingState::
461
- OnReceiveSettings(void* arg, grpc_error_handle /* error */) {
462
- HandshakingState* self = static_cast<HandshakingState*>(arg);
463
- {
464
- MutexLock lock(&self->connection_->mu_);
465
- if (self->timer_handle_.has_value()) {
466
- self->connection_->event_engine_->Cancel(*self->timer_handle_);
467
- self->timer_handle_.reset();
468
- }
469
- }
470
- self->Unref();
471
- }
472
-
473
- void Chttp2ServerListener::ActiveConnection::HandshakingState::OnHandshakeDone(
474
- absl::StatusOr<HandshakerArgs*> result) {
475
- OrphanablePtr<HandshakingState> handshaking_state_ref;
476
- RefCountedPtr<HandshakeManager> handshake_mgr;
477
- bool cleanup_connection = false;
478
- bool release_connection = false;
479
- {
480
- MutexLock connection_lock(&connection_->mu_);
481
- if (!result.ok() || connection_->shutdown_) {
482
- cleanup_connection = true;
483
- release_connection = true;
484
- } else {
485
- // If the handshaking succeeded but there is no endpoint, then the
486
- // handshaker may have handed off the connection to some external
487
- // code, so we can just clean up here without creating a transport.
488
- if ((*result)->endpoint != nullptr) {
489
- RefCountedPtr<Transport> transport =
490
- grpc_create_chttp2_transport((*result)->args,
491
- std::move((*result)->endpoint), false)
492
- ->Ref();
493
- grpc_error_handle channel_init_err =
494
- connection_->listener_->server_->SetupTransport(
495
- transport.get(), accepting_pollset_, (*result)->args,
496
- grpc_chttp2_transport_get_socket_node(transport.get()));
497
- if (channel_init_err.ok()) {
498
- // Use notify_on_receive_settings callback to enforce the
499
- // handshake deadline.
500
- connection_->transport_ =
501
- DownCast<grpc_chttp2_transport*>(transport.get())->Ref();
502
- Ref().release(); // Held by OnReceiveSettings().
503
- GRPC_CLOSURE_INIT(&on_receive_settings_, OnReceiveSettings, this,
504
- grpc_schedule_on_exec_ctx);
505
- // If the listener has been configured with a config fetcher, we
506
- // need to watch on the transport being closed so that we can an
507
- // updated list of active connections.
508
- grpc_closure* on_close = nullptr;
509
- if (connection_->listener_->config_fetcher_watcher_ != nullptr) {
510
- // Refs helds by OnClose()
511
- connection_->Ref().release();
512
- on_close = &connection_->on_close_;
513
- } else {
514
- // Remove the connection from the connections_ map since OnClose()
515
- // will not be invoked when a config fetcher is set.
516
- auto connection_quota =
517
- connection_->listener_->connection_quota_->Ref().release();
518
- auto on_close_transport = [](void* arg,
519
- grpc_error_handle /*handle*/) {
520
- ConnectionQuota* connection_quota =
521
- static_cast<ConnectionQuota*>(arg);
522
- connection_quota->ReleaseConnections(1);
523
- connection_quota->Unref();
524
- };
525
- on_close = GRPC_CLOSURE_CREATE(on_close_transport, connection_quota,
526
- grpc_schedule_on_exec_ctx_);
527
- cleanup_connection = true;
528
- }
529
- grpc_chttp2_transport_start_reading(
530
- transport.get(), (*result)->read_buffer.c_slice_buffer(),
531
- &on_receive_settings_, nullptr, on_close);
532
- timer_handle_ = connection_->event_engine_->RunAfter(
533
- deadline_ - Timestamp::Now(), [self = Ref()]() mutable {
534
- ExecCtx exec_ctx;
535
- self->OnTimeout();
536
- // HandshakingState deletion might require an active ExecCtx.
537
- self.reset();
538
- });
539
- } else {
540
- // Failed to create channel from transport. Clean up.
541
- LOG(ERROR) << "Failed to create channel: "
542
- << StatusToString(channel_init_err);
543
- transport->Orphan();
544
- cleanup_connection = true;
545
- release_connection = true;
546
- }
547
- } else {
548
- cleanup_connection = true;
549
- release_connection = true;
550
- }
551
- }
552
- // Since the handshake manager is done, the connection no longer needs to
553
- // shutdown the handshake when the listener needs to stop serving.
554
- // Avoid calling the destructor of HandshakeManager and HandshakingState
555
- // from within the critical region.
556
- handshake_mgr = std::move(handshake_mgr_);
557
- handshaking_state_ref = std::move(connection_->handshaking_state_);
558
- }
559
- OrphanablePtr<ActiveConnection> connection;
560
- if (cleanup_connection) {
561
- MutexLock listener_lock(&connection_->listener_->mu_);
562
- if (release_connection) {
563
- connection_->listener_->connection_quota_->ReleaseConnections(1);
564
- }
565
- auto it = connection_->listener_->connections_.find(connection_.get());
566
- if (it != connection_->listener_->connections_.end()) {
567
- connection = std::move(it->second);
568
- connection_->listener_->connections_.erase(it);
569
- }
570
- }
571
- }
572
-
573
- //
574
- // Chttp2ServerListener::ActiveConnection
575
- //
576
-
577
- Chttp2ServerListener::ActiveConnection::ActiveConnection(
578
- RefCountedPtr<Chttp2ServerListener> listener,
579
- grpc_pollset* accepting_pollset, AcceptorPtr acceptor,
580
- EventEngine* event_engine, const ChannelArgs& args,
581
- MemoryOwner memory_owner)
582
- : listener_(std::move(listener)),
583
- handshaking_state_(memory_owner.MakeOrphanable<HandshakingState>(
584
- Ref(), accepting_pollset, std::move(acceptor), args)),
585
- event_engine_(event_engine) {
586
- GRPC_CLOSURE_INIT(&on_close_, ActiveConnection::OnClose, this,
587
- grpc_schedule_on_exec_ctx);
588
- }
589
-
590
- void Chttp2ServerListener::ActiveConnection::Orphan() {
591
- OrphanablePtr<HandshakingState> handshaking_state;
592
- {
593
- MutexLock lock(&mu_);
594
- shutdown_ = true;
595
- // Reset handshaking_state_ since we have been orphaned by the listener
596
- // signaling that the listener has stopped serving.
597
- handshaking_state = std::move(handshaking_state_);
598
- }
599
- Unref();
600
- }
601
-
602
- void Chttp2ServerListener::ActiveConnection::SendGoAway() {
603
- grpc_chttp2_transport* transport = nullptr;
604
- {
605
- MutexLock lock(&mu_);
606
- if (!shutdown_) {
607
- // Send a GOAWAY if the transport exists
608
- if (transport_ != nullptr) {
609
- transport = transport_.get();
610
- drain_grace_timer_handle_ = event_engine_->RunAfter(
611
- std::max(Duration::Zero(),
612
- listener_->args_
613
- .GetDurationFromIntMillis(
614
- GRPC_ARG_SERVER_CONFIG_CHANGE_DRAIN_GRACE_TIME_MS)
615
- .value_or(Duration::Minutes(10))),
616
- [self = Ref(DEBUG_LOCATION, "drain_grace_timer")]() mutable {
617
- ExecCtx exec_ctx;
618
- self->OnDrainGraceTimeExpiry();
619
- self.reset(DEBUG_LOCATION, "drain_grace_timer");
620
- });
621
- }
622
- // Shutdown the handshaker if it's still in progress.
623
- if (handshaking_state_ != nullptr) {
624
- handshaking_state_->ShutdownLocked(
625
- absl::UnavailableError("Connection going away"));
626
- }
627
- shutdown_ = true;
628
- }
629
- }
630
- if (transport != nullptr) {
631
- grpc_transport_op* op = grpc_make_transport_op(nullptr);
632
- // Set an HTTP2 error of NO_ERROR to do graceful GOAWAYs.
633
- op->goaway_error = grpc_error_set_int(
634
- GRPC_ERROR_CREATE("Server is stopping to serve requests."),
635
- StatusIntProperty::kHttp2Error,
636
- static_cast<intptr_t>(Http2ErrorCode::kNoError));
637
- transport->PerformOp(op);
638
- }
639
- }
640
-
641
- void Chttp2ServerListener::ActiveConnection::Start(
642
- OrphanablePtr<grpc_endpoint> endpoint, const ChannelArgs& args) {
643
- RefCountedPtr<HandshakingState> handshaking_state_ref;
644
- {
645
- MutexLock lock(&mu_);
646
- connection_started_ = true;
647
- // If the Connection is already shutdown at this point, it implies the
648
- // owning Chttp2ServerListener and all associated ActiveConnections have
649
- // been orphaned.
650
- if (shutdown_) return;
651
- // Hold a ref to HandshakingState to allow starting the handshake outside
652
- // the critical region.
653
- handshaking_state_ref = handshaking_state_->Ref();
654
- }
655
- handshaking_state_ref->Start(std::move(endpoint), args);
656
- }
657
-
658
- void Chttp2ServerListener::ActiveConnection::OnClose(
659
- void* arg, grpc_error_handle /* error */) {
660
- ActiveConnection* self = static_cast<ActiveConnection*>(arg);
661
- OrphanablePtr<ActiveConnection> connection;
662
- {
663
- MutexLock listener_lock(&self->listener_->mu_);
664
- MutexLock connection_lock(&self->mu_);
665
- // The node was already deleted from the connections_ list if the
666
- // connection is shutdown.
667
- if (!self->shutdown_) {
668
- auto it = self->listener_->connections_.find(self);
669
- if (it != self->listener_->connections_.end()) {
670
- connection = std::move(it->second);
671
- self->listener_->connections_.erase(it);
672
- }
673
- self->shutdown_ = true;
674
- }
675
- // Cancel the drain_grace_timer_ if needed.
676
- if (self->drain_grace_timer_handle_.has_value()) {
677
- self->event_engine_->Cancel(*self->drain_grace_timer_handle_);
678
- self->drain_grace_timer_handle_.reset();
679
- }
680
- }
681
- self->listener_->connection_quota_->ReleaseConnections(1);
682
- self->Unref();
683
- }
684
-
685
- void Chttp2ServerListener::ActiveConnection::OnDrainGraceTimeExpiry() {
686
- grpc_chttp2_transport* transport = nullptr;
687
- // If the drain_grace_timer_ was not cancelled, disconnect the transport
688
- // immediately.
689
- {
690
- MutexLock lock(&mu_);
691
- if (drain_grace_timer_handle_.has_value()) {
692
- transport = transport_.get();
693
- drain_grace_timer_handle_.reset();
694
- }
695
- }
696
- if (transport != nullptr) {
697
- grpc_transport_op* op = grpc_make_transport_op(nullptr);
698
- op->disconnect_with_error = GRPC_ERROR_CREATE(
699
- "Drain grace time expired. Closing connection immediately.");
700
- transport->PerformOp(op);
701
- }
702
- }
703
-
704
- //
705
- // Chttp2ServerListener
706
- //
707
-
708
- grpc_error_handle Chttp2ServerListener::Create(
709
- Server* server, const EventEngine::ResolvedAddress& addr,
710
- const ChannelArgs& args, int* port_num) {
711
- // Create Chttp2ServerListener.
712
- OrphanablePtr<Chttp2ServerListener> listener =
713
- MakeOrphanable<Chttp2ServerListener>(server, args,
714
- server->config_fetcher());
715
- // The tcp_server will be unreffed when the listener is orphaned, which could
716
- // be at the end of this function if the listener was not added to the
717
- // server's set of listeners.
718
- grpc_error_handle error = grpc_tcp_server_create(
719
- &listener->tcp_server_shutdown_complete_, ChannelArgsEndpointConfig(args),
720
- OnAccept, listener.get(), &listener->tcp_server_);
721
- if (!error.ok()) return error;
722
- // TODO(yijiem): remove this conversion when we remove all
723
- // grpc_resolved_address usages.
724
- grpc_resolved_address iomgr_addr =
725
- grpc_event_engine::experimental::CreateGRPCResolvedAddress(addr);
726
- if (listener->config_fetcher_ != nullptr) {
727
- listener->resolved_address_ = iomgr_addr;
728
- // TODO(yashykt): Consider binding so as to be able to return the port
729
- // number.
730
- } else {
731
- error =
732
- grpc_tcp_server_add_port(listener->tcp_server_, &iomgr_addr, port_num);
733
- if (!error.ok()) return error;
734
- }
735
- // Create channelz node.
736
- if (args.GetBool(GRPC_ARG_ENABLE_CHANNELZ)
737
- .value_or(GRPC_ENABLE_CHANNELZ_DEFAULT)) {
738
- auto string_address =
739
- grpc_event_engine::experimental::ResolvedAddressToURI(addr);
740
- if (!string_address.ok()) {
741
- return GRPC_ERROR_CREATE(string_address.status().ToString());
742
- }
743
- listener->channelz_listen_socket_ =
744
- MakeRefCounted<channelz::ListenSocketNode>(
745
- *string_address, absl::StrCat("chttp2 listener ", *string_address));
746
- }
747
- // Register with the server only upon success
748
- server->AddListener(std::move(listener));
749
- return absl::OkStatus();
750
- }
751
-
752
- grpc_error_handle Chttp2ServerListener::CreateWithAcceptor(
753
- Server* server, const char* name, const ChannelArgs& args) {
754
- auto listener = MakeOrphanable<Chttp2ServerListener>(
755
- server, args, server->config_fetcher());
756
- grpc_error_handle error = grpc_tcp_server_create(
757
- &listener->tcp_server_shutdown_complete_, ChannelArgsEndpointConfig(args),
758
- OnAccept, listener.get(), &listener->tcp_server_);
759
- if (!error.ok()) return error;
760
- // TODO(yangg) channelz
761
- TcpServerFdHandler** arg_val = args.GetPointer<TcpServerFdHandler*>(name);
762
- *arg_val = grpc_tcp_server_create_fd_handler(listener->tcp_server_);
763
- server->AddListener(std::move(listener));
764
- return absl::OkStatus();
765
- }
766
-
767
- Chttp2ServerListener* Chttp2ServerListener::CreateForPassiveListener(
768
- Server* server, const ChannelArgs& args,
769
- std::shared_ptr<experimental::PassiveListenerImpl> passive_listener) {
770
- // TODO(hork): figure out how to handle channelz in this case
771
- auto listener = MakeOrphanable<Chttp2ServerListener>(
772
- server, args, nullptr, std::move(passive_listener));
773
- auto listener_ptr = listener.get();
774
- server->AddListener(std::move(listener));
775
- return listener_ptr;
776
- }
777
-
778
- Chttp2ServerListener::Chttp2ServerListener(
779
- Server* server, const ChannelArgs& args,
780
- ServerConfigFetcher* config_fetcher,
781
- std::shared_ptr<experimental::PassiveListenerImpl> passive_listener)
782
- : server_(server),
783
- args_(args),
784
- memory_quota_(args.GetObject<ResourceQuota>()->memory_quota()),
785
- connection_quota_(MakeRefCounted<ConnectionQuota>()),
786
- config_fetcher_(config_fetcher),
787
- passive_listener_(std::move(passive_listener)) {
788
- auto max_allowed_incoming_connections =
789
- args.GetInt(GRPC_ARG_MAX_ALLOWED_INCOMING_CONNECTIONS);
790
- if (max_allowed_incoming_connections.has_value()) {
791
- connection_quota_->SetMaxIncomingConnections(
792
- max_allowed_incoming_connections.value());
793
- }
794
- GRPC_CLOSURE_INIT(&tcp_server_shutdown_complete_, TcpServerShutdownComplete,
795
- this, grpc_schedule_on_exec_ctx);
796
- }
797
-
798
- Chttp2ServerListener::~Chttp2ServerListener() {
799
- if (passive_listener_ != nullptr) {
800
- passive_listener_->ListenerDestroyed();
801
- }
802
- if (on_destroy_done_ != nullptr) {
803
- ExecCtx::Run(DEBUG_LOCATION, on_destroy_done_, absl::OkStatus());
804
- }
805
- }
806
-
807
- // Server callback: start listening on our ports
808
- void Chttp2ServerListener::Start() {
809
- if (config_fetcher_ != nullptr) {
810
- auto watcher = std::make_unique<ConfigFetcherWatcher>(
811
- RefAsSubclass<Chttp2ServerListener>());
812
- config_fetcher_watcher_ = watcher.get();
813
- config_fetcher_->StartWatch(
814
- grpc_sockaddr_to_string(&resolved_address_, false).value(),
815
- std::move(watcher));
816
- } else {
817
- {
818
- MutexLock lock(&mu_);
819
- started_ = true;
820
- is_serving_ = true;
821
- }
822
- StartListening();
823
- }
824
- }
825
-
826
- void Chttp2ServerListener::StartListening() {
827
- if (tcp_server_ != nullptr) {
828
- grpc_tcp_server_start(tcp_server_, &server_->pollsets());
829
- }
830
- }
831
-
832
- void Chttp2ServerListener::SetOnDestroyDone(grpc_closure* on_destroy_done) {
833
- MutexLock lock(&mu_);
834
- on_destroy_done_ = on_destroy_done;
835
- }
836
-
837
- void Chttp2ServerListener::AcceptConnectedEndpoint(
838
- std::unique_ptr<EventEngine::Endpoint> endpoint) {
839
- OnAccept(this, grpc_event_engine_endpoint_create(std::move(endpoint)),
840
- /*accepting_pollset=*/nullptr, /*acceptor=*/nullptr);
841
- }
842
-
843
- namespace {
844
-
845
- ChannelArgs ModifyArgsForConnection(const ChannelArgs& args,
846
- grpc_error_handle* error) {
847
- auto* server_credentials = args.GetObject<grpc_server_credentials>();
848
- if (server_credentials == nullptr) {
849
- *error = GRPC_ERROR_CREATE("Could not find server credentials");
850
- return args;
851
- }
852
- auto security_connector = server_credentials->create_security_connector(args);
853
- if (security_connector == nullptr) {
854
- *error = GRPC_ERROR_CREATE(
855
- absl::StrCat("Unable to create secure server with credentials of type ",
856
- server_credentials->type().name()));
857
- return args;
858
- }
859
- return args.SetObject(security_connector);
860
- }
861
-
862
- } // namespace
863
-
864
- void Chttp2ServerListener::OnAccept(void* arg, grpc_endpoint* tcp,
865
- grpc_pollset* accepting_pollset,
866
- grpc_tcp_server_acceptor* server_acceptor) {
867
- Chttp2ServerListener* self = static_cast<Chttp2ServerListener*>(arg);
868
- ChannelArgs args = self->args_;
869
- OrphanablePtr<grpc_endpoint> endpoint(tcp);
870
- AcceptorPtr acceptor(server_acceptor);
871
- RefCountedPtr<ServerConfigFetcher::ConnectionManager> connection_manager;
872
- {
873
- MutexLock lock(&self->mu_);
874
- connection_manager = self->connection_manager_;
875
- }
876
- if (!self->connection_quota_->AllowIncomingConnection(
877
- self->memory_quota_, grpc_endpoint_get_peer(endpoint.get()))) {
878
- return;
879
- }
880
- if (self->config_fetcher_ != nullptr) {
881
- if (connection_manager == nullptr) {
882
- return;
883
- }
884
- absl::StatusOr<ChannelArgs> args_result =
885
- connection_manager->UpdateChannelArgsForConnection(args, tcp);
886
- if (!args_result.ok()) {
887
- return;
888
- }
889
- grpc_error_handle error;
890
- args = ModifyArgsForConnection(*args_result, &error);
891
- if (!error.ok()) {
892
- return;
893
- }
894
- }
895
- auto memory_owner = self->memory_quota_->CreateMemoryOwner();
896
- EventEngine* const event_engine = self->args_.GetObject<EventEngine>();
897
- auto connection = memory_owner.MakeOrphanable<ActiveConnection>(
898
- self->RefAsSubclass<Chttp2ServerListener>(), accepting_pollset,
899
- std::move(acceptor), event_engine, args, std::move(memory_owner));
900
- // Hold a ref to connection to allow starting handshake outside the
901
- // critical region
902
- RefCountedPtr<ActiveConnection> connection_ref = connection->Ref();
903
- {
904
- MutexLock lock(&self->mu_);
905
- // Shutdown the the connection if listener's stopped serving or if the
906
- // connection manager has changed.
907
- if (!self->shutdown_ && self->is_serving_ &&
908
- connection_manager == self->connection_manager_) {
909
- // The ref for the tcp_server needs to be taken in the critical region
910
- // after having made sure that the listener has not been Orphaned, so as
911
- // to avoid heap-use-after-free issues where `Ref()` is invoked when the
912
- // listener is already shutdown. Note that the listener holds a ref to the
913
- // tcp_server but this ref is given away when the listener is orphaned
914
- // (shutdown). A connection needs the tcp_server to outlast the handshake
915
- // since the acceptor needs it.
916
- if (self->tcp_server_ != nullptr) {
917
- grpc_tcp_server_ref(self->tcp_server_);
918
- }
919
- self->connections_.emplace(connection.get(), std::move(connection));
920
- }
921
- }
922
- if (connection == nullptr) {
923
- connection_ref->Start(std::move(endpoint), args);
924
- }
925
- }
926
-
927
- void Chttp2ServerListener::TcpServerShutdownComplete(
928
- void* arg, grpc_error_handle /*error*/) {
929
- Chttp2ServerListener* self = static_cast<Chttp2ServerListener*>(arg);
930
- self->channelz_listen_socket_.reset();
931
- self->Unref();
932
- }
933
-
934
- // Server callback: destroy the tcp listener (so we don't generate further
935
- // callbacks)
936
- void Chttp2ServerListener::Orphan() {
937
- // Cancel the watch before shutting down so as to avoid holding a ref to the
938
- // listener in the watcher.
939
- if (config_fetcher_watcher_ != nullptr) {
940
- CHECK_NE(config_fetcher_, nullptr);
941
- config_fetcher_->CancelWatch(config_fetcher_watcher_);
942
- }
943
- std::map<ActiveConnection*, OrphanablePtr<ActiveConnection>> connections;
944
- grpc_tcp_server* tcp_server;
945
- {
946
- MutexLock lock(&mu_);
947
- shutdown_ = true;
948
- is_serving_ = false;
949
- // Orphan the connections so that they can start cleaning up.
950
- connections = std::move(connections_);
951
- // If the listener is currently set to be serving but has not been started
952
- // yet, it means that `grpc_tcp_server_start` is in progress. Wait for the
953
- // operation to finish to avoid causing races.
954
- while (is_serving_ && !started_) {
955
- started_cv_.Wait(&mu_);
956
- }
957
- tcp_server = tcp_server_;
958
- }
959
- if (tcp_server != nullptr) {
960
- grpc_tcp_server_shutdown_listeners(tcp_server);
961
- grpc_tcp_server_unref(tcp_server);
962
- } else {
963
- Unref();
964
- }
965
- }
966
-
967
124
  //
968
125
  // NewChttp2ServerListener::ActiveConnection::HandshakingState
969
126
  //
@@ -1078,8 +235,7 @@ void NewChttp2ServerListener::ActiveConnection::HandshakingState::
1078
235
  ->Ref();
1079
236
  grpc_error_handle channel_init_err =
1080
237
  connection_->listener_state_->server()->SetupTransport(
1081
- transport.get(), accepting_pollset_, (*result)->args,
1082
- grpc_chttp2_transport_get_socket_node(transport.get()));
238
+ transport.get(), accepting_pollset_, (*result)->args);
1083
239
  if (channel_init_err.ok()) {
1084
240
  // Use notify_on_receive_settings callback to enforce the
1085
241
  // handshake deadline.
@@ -1457,21 +613,17 @@ void NewChttp2ServerListener::Orphan() {
1457
613
  }
1458
614
  }
1459
615
 
1460
- namespace {
1461
-
1462
- grpc_error_handle Chttp2ServerAddPort(Server* server, const char* addr,
1463
- const ChannelArgs& args, int* port_num) {
616
+ absl::StatusOr<int> Chttp2ServerAddPort(Server* server, const char* addr,
617
+ const ChannelArgs& args) {
1464
618
  if (addr == nullptr) {
1465
619
  return GRPC_ERROR_CREATE("Invalid address: addr cannot be a nullptr.");
1466
620
  }
1467
621
  if (strncmp(addr, "external:", 9) == 0) {
1468
- if (IsServerListenerEnabled()) {
1469
- return NewChttp2ServerListener::CreateWithAcceptor(server, addr, args);
1470
- } else {
1471
- return Chttp2ServerListener::CreateWithAcceptor(server, addr, args);
1472
- }
622
+ auto r = NewChttp2ServerListener::CreateWithAcceptor(server, addr, args);
623
+ if (!r.ok()) return r;
624
+ return -1;
1473
625
  }
1474
- *port_num = -1;
626
+ int port_num = -1;
1475
627
  absl::StatusOr<std::vector<grpc_resolved_address>> resolved;
1476
628
  absl::StatusOr<std::vector<EventEngine::ResolvedAddress>> results =
1477
629
  std::vector<EventEngine::ResolvedAddress>();
@@ -1527,24 +679,19 @@ grpc_error_handle Chttp2ServerAddPort(Server* server, const char* addr,
1527
679
  for (EventEngine::ResolvedAddress& addr : *results) {
1528
680
  // If address has a wildcard port (0), use the same port as a previous
1529
681
  // listener.
1530
- if (*port_num != -1 &&
682
+ if (port_num != -1 &&
1531
683
  grpc_event_engine::experimental::ResolvedAddressGetPort(addr) == 0) {
1532
- grpc_event_engine::experimental::ResolvedAddressSetPort(addr,
1533
- *port_num);
684
+ grpc_event_engine::experimental::ResolvedAddressSetPort(addr, port_num);
1534
685
  }
1535
686
  int port_temp = -1;
1536
- if (IsServerListenerEnabled()) {
1537
- error = NewChttp2ServerListener::Create(server, addr, args, &port_temp);
1538
- } else {
1539
- error = Chttp2ServerListener::Create(server, addr, args, &port_temp);
1540
- }
687
+ error = NewChttp2ServerListener::Create(server, addr, args, &port_temp);
1541
688
  if (!error.ok()) {
1542
689
  error_list.push_back(error);
1543
690
  } else {
1544
- if (*port_num == -1) {
1545
- *port_num = port_temp;
691
+ if (port_num == -1) {
692
+ port_num = port_temp;
1546
693
  } else {
1547
- CHECK(*port_num == port_temp);
694
+ CHECK(port_num == port_temp);
1548
695
  }
1549
696
  }
1550
697
  }
@@ -1566,51 +713,30 @@ grpc_error_handle Chttp2ServerAddPort(Server* server, const char* addr,
1566
713
  }
1567
714
  return absl::OkStatus();
1568
715
  }(); // lambda end
1569
- if (!error.ok()) *port_num = 0;
1570
- return error;
716
+ if (!error.ok()) return error;
717
+ return port_num;
1571
718
  }
1572
719
 
1573
- } // namespace
1574
-
1575
720
  namespace experimental {
1576
721
 
1577
722
  absl::Status PassiveListenerImpl::AcceptConnectedEndpoint(
1578
723
  std::unique_ptr<EventEngine::Endpoint> endpoint) {
1579
724
  CHECK_NE(server_.get(), nullptr);
1580
- if (IsServerListenerEnabled()) {
1581
- RefCountedPtr<NewChttp2ServerListener> new_listener;
1582
- {
1583
- MutexLock lock(&mu_);
1584
- auto* new_listener_ptr =
1585
- std::get_if<NewChttp2ServerListener*>(&listener_);
1586
- if (new_listener_ptr != nullptr && *new_listener_ptr != nullptr) {
1587
- new_listener = (*new_listener_ptr)
1588
- ->RefIfNonZero()
1589
- .TakeAsSubclass<NewChttp2ServerListener>();
1590
- }
1591
- }
1592
- if (new_listener == nullptr) {
1593
- return absl::UnavailableError("passive listener already shut down");
1594
- }
1595
- ExecCtx exec_ctx;
1596
- new_listener->AcceptConnectedEndpoint(std::move(endpoint));
1597
- } else {
1598
- RefCountedPtr<Chttp2ServerListener> listener;
1599
- {
1600
- MutexLock lock(&mu_);
1601
- auto* listener_ptr = std::get_if<Chttp2ServerListener*>(&listener_);
1602
- if (listener_ptr != nullptr && *listener_ptr != nullptr) {
1603
- listener = (*listener_ptr)
1604
- ->RefIfNonZero()
1605
- .TakeAsSubclass<Chttp2ServerListener>();
1606
- }
1607
- }
1608
- if (listener == nullptr) {
1609
- return absl::UnavailableError("passive listener already shut down");
725
+ RefCountedPtr<NewChttp2ServerListener> new_listener;
726
+ {
727
+ MutexLock lock(&mu_);
728
+ auto* new_listener_ptr = std::get_if<NewChttp2ServerListener*>(&listener_);
729
+ if (new_listener_ptr != nullptr && *new_listener_ptr != nullptr) {
730
+ new_listener = (*new_listener_ptr)
731
+ ->RefIfNonZero()
732
+ .TakeAsSubclass<NewChttp2ServerListener>();
1610
733
  }
1611
- ExecCtx exec_ctx;
1612
- listener->AcceptConnectedEndpoint(std::move(endpoint));
1613
734
  }
735
+ if (new_listener == nullptr) {
736
+ return absl::UnavailableError("passive listener already shut down");
737
+ }
738
+ ExecCtx exec_ctx;
739
+ new_listener->AcceptConnectedEndpoint(std::move(endpoint));
1614
740
  return absl::OkStatus();
1615
741
  }
1616
742
 
@@ -1619,7 +745,7 @@ absl::Status PassiveListenerImpl::AcceptConnectedFd(int fd) {
1619
745
  ExecCtx exec_ctx;
1620
746
  auto& args = server_->channel_args();
1621
747
  auto* supports_fd = QueryExtension<EventEngineSupportsFdExtension>(
1622
- /*engine=*/args.GetObjectRef<EventEngine>().get());
748
+ args.GetObjectRef<EventEngine>().get());
1623
749
  if (supports_fd == nullptr) {
1624
750
  return absl::UnimplementedError(
1625
751
  "The server's EventEngine does not support adding endpoints from "
@@ -1638,55 +764,6 @@ void PassiveListenerImpl::ListenerDestroyed() {
1638
764
  } // namespace experimental
1639
765
  } // namespace grpc_core
1640
766
 
1641
- int grpc_server_add_http2_port(grpc_server* server, const char* addr,
1642
- grpc_server_credentials* creds) {
1643
- grpc_core::ExecCtx exec_ctx;
1644
- grpc_error_handle err;
1645
- grpc_core::RefCountedPtr<grpc_server_security_connector> sc;
1646
- int port_num = 0;
1647
- grpc_core::Server* core_server = grpc_core::Server::FromC(server);
1648
- grpc_core::ChannelArgs args = core_server->channel_args();
1649
- GRPC_TRACE_LOG(api, INFO) << "grpc_server_add_http2_port(server=" << server
1650
- << ", addr=" << addr << ", creds=" << creds << ")";
1651
- // Create security context.
1652
- if (creds == nullptr) {
1653
- err = GRPC_ERROR_CREATE(
1654
- "No credentials specified for secure server port (creds==NULL)");
1655
- goto done;
1656
- }
1657
- // TODO(yashykt): Ideally, we would not want to have different behavior here
1658
- // based on whether a config fetcher is configured or not. Currently, we have
1659
- // a feature for SSL credentials reloading with an application callback that
1660
- // assumes that there is a single security connector. If we delay the creation
1661
- // of the security connector to after the creation of the listener(s), we
1662
- // would have potentially multiple security connectors which breaks the
1663
- // assumption for SSL creds reloading. When the API for SSL creds reloading is
1664
- // rewritten, we would be able to make this workaround go away by removing
1665
- // that assumption. As an immediate drawback of this workaround, config
1666
- // fetchers need to be registered before adding ports to the server.
1667
- if (core_server->config_fetcher() != nullptr) {
1668
- // Create channel args.
1669
- args = args.SetObject(creds->Ref());
1670
- } else {
1671
- sc = creds->create_security_connector(grpc_core::ChannelArgs());
1672
- if (sc == nullptr) {
1673
- err = GRPC_ERROR_CREATE(absl::StrCat(
1674
- "Unable to create secure server with credentials of type ",
1675
- creds->type().name()));
1676
- goto done;
1677
- }
1678
- args = args.SetObject(creds->Ref()).SetObject(sc);
1679
- }
1680
- // Add server port.
1681
- err = grpc_core::Chttp2ServerAddPort(core_server, addr, args, &port_num);
1682
- done:
1683
- sc.reset(DEBUG_LOCATION, "server");
1684
- if (!err.ok()) {
1685
- LOG(ERROR) << grpc_core::StatusToString(err);
1686
- }
1687
- return port_num;
1688
- }
1689
-
1690
767
  #ifdef GPR_SUPPORT_CHANNELS_FROM_FD
1691
768
  void grpc_server_add_channel_from_fd(grpc_server* server, int fd,
1692
769
  grpc_server_credentials* creds) {
@@ -1716,7 +793,7 @@ void grpc_server_add_channel_from_fd(grpc_server* server, int fd,
1716
793
  server_args, std::move(server_endpoint), false // is_client
1717
794
  );
1718
795
  grpc_error_handle error =
1719
- core_server->SetupTransport(transport, nullptr, server_args, nullptr);
796
+ core_server->SetupTransport(transport, nullptr, server_args);
1720
797
  if (error.ok()) {
1721
798
  grpc_chttp2_transport_start_reading(transport, nullptr, nullptr, nullptr,
1722
799
  nullptr);
@@ -1758,15 +835,9 @@ absl::Status grpc_server_add_passive_listener(
1758
835
  auto args = server->channel_args()
1759
836
  .SetObject(credentials->Ref())
1760
837
  .SetObject(std::move(sc));
1761
- if (grpc_core::IsServerListenerEnabled()) {
1762
- passive_listener->listener_ =
1763
- grpc_core::NewChttp2ServerListener::CreateForPassiveListener(
1764
- server, args, passive_listener);
1765
- } else {
1766
- passive_listener->listener_ =
1767
- grpc_core::Chttp2ServerListener::CreateForPassiveListener(
1768
- server, args, passive_listener);
1769
- }
838
+ passive_listener->listener_ =
839
+ grpc_core::NewChttp2ServerListener::CreateForPassiveListener(
840
+ server, args, passive_listener);
1770
841
 
1771
842
  passive_listener->server_ = server->Ref();
1772
843
  return absl::OkStatus();