grpc 1.46.3-x86_64-linux → 1.48.0-x86_64-linux

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.

Potentially problematic release.


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

Files changed (816) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +138 -128
  3. data/include/grpc/compression.h +1 -1
  4. data/include/grpc/event_engine/event_engine.h +62 -18
  5. data/include/grpc/event_engine/memory_allocator.h +0 -15
  6. data/include/grpc/event_engine/port.h +1 -1
  7. data/include/grpc/event_engine/slice.h +286 -0
  8. data/include/grpc/event_engine/slice_buffer.h +118 -0
  9. data/include/grpc/grpc.h +3 -3
  10. data/include/grpc/grpc_security.h +11 -0
  11. data/include/grpc/impl/codegen/compression_types.h +2 -1
  12. data/include/grpc/impl/codegen/connectivity_state.h +2 -1
  13. data/include/grpc/impl/codegen/gpr_types.h +2 -1
  14. data/include/grpc/impl/codegen/grpc_types.h +2 -1
  15. data/include/grpc/impl/codegen/port_platform.h +106 -39
  16. data/include/grpc/impl/codegen/slice.h +1 -1
  17. data/src/core/ext/filters/census/grpc_context.cc +3 -0
  18. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +35 -35
  19. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +20 -1
  20. data/src/core/ext/filters/channel_idle/idle_filter_state.h +2 -0
  21. data/src/core/ext/filters/client_channel/backend_metric.cc +17 -12
  22. data/src/core/ext/filters/client_channel/backend_metric.h +19 -9
  23. data/src/core/ext/filters/client_channel/backup_poller.cc +8 -6
  24. data/src/core/ext/filters/client_channel/backup_poller.h +2 -4
  25. data/src/core/ext/filters/client_channel/channel_connectivity.cc +43 -21
  26. data/src/core/ext/filters/client_channel/client_channel.cc +111 -82
  27. data/src/core/ext/filters/client_channel/client_channel.h +43 -8
  28. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +3 -5
  29. data/src/core/ext/filters/client_channel/client_channel_channelz.h +12 -2
  30. data/src/core/ext/filters/client_channel/client_channel_factory.cc +5 -0
  31. data/src/core/ext/filters/client_channel/client_channel_factory.h +8 -0
  32. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +4 -13
  33. data/src/core/ext/filters/client_channel/config_selector.cc +1 -0
  34. data/src/core/ext/filters/client_channel/config_selector.h +8 -6
  35. data/src/core/ext/filters/client_channel/connector.h +9 -3
  36. data/src/core/ext/filters/client_channel/dynamic_filters.cc +19 -6
  37. data/src/core/ext/filters/client_channel/dynamic_filters.h +12 -2
  38. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +2 -0
  39. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +3 -0
  40. data/src/core/ext/filters/client_channel/health/health_check_client.cc +14 -1
  41. data/src/core/ext/filters/client_channel/health/health_check_client.h +2 -0
  42. data/src/core/ext/filters/client_channel/http_proxy.cc +10 -2
  43. data/src/core/ext/filters/client_channel/http_proxy.h +3 -0
  44. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +6 -2
  45. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +1 -0
  46. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +49 -0
  47. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +12 -0
  48. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +5 -0
  49. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +11 -5
  50. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +1 -0
  51. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +132 -62
  52. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +4 -0
  53. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +6 -0
  54. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +10 -1
  55. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +6 -3
  56. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +407 -0
  57. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +57 -0
  58. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +1036 -0
  59. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +54 -0
  60. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +149 -147
  61. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +176 -85
  62. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +303 -203
  63. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +6 -1
  64. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +92 -54
  65. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +240 -214
  66. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +119 -111
  67. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +86 -71
  68. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +101 -25
  69. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +6 -0
  70. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +35 -11
  71. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +36 -20
  72. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +78 -14
  73. data/src/core/ext/filters/client_channel/lb_policy.cc +4 -2
  74. data/src/core/ext/filters/client_channel/lb_policy.h +18 -31
  75. data/src/core/ext/filters/client_channel/lb_policy_factory.h +2 -0
  76. data/src/core/ext/filters/client_channel/lb_policy_registry.cc +11 -6
  77. data/src/core/ext/filters/client_channel/lb_policy_registry.h +6 -1
  78. data/src/core/ext/filters/client_channel/local_subchannel_pool.cc +4 -0
  79. data/src/core/ext/filters/client_channel/local_subchannel_pool.h +1 -0
  80. data/src/core/ext/filters/client_channel/proxy_mapper.h +1 -1
  81. data/src/core/ext/filters/client_channel/proxy_mapper_registry.cc +1 -0
  82. data/src/core/ext/filters/client_channel/proxy_mapper_registry.h +5 -0
  83. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +26 -6
  84. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +139 -48
  85. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +8 -1
  86. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +10 -8
  87. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +6 -6
  88. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +36 -14
  89. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +13 -4
  90. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +2 -1
  91. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.cc +2 -0
  92. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.h +2 -1
  93. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +39 -7
  94. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +18 -19
  95. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +5 -2
  96. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +61 -16
  97. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +14 -2
  98. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +8 -1
  99. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +17 -12
  100. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +111 -46
  101. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +3 -1
  102. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +12 -18
  103. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +11 -5
  104. data/src/core/ext/filters/client_channel/retry_filter.cc +75 -36
  105. data/src/core/ext/filters/client_channel/retry_filter.h +1 -0
  106. data/src/core/ext/filters/client_channel/retry_service_config.cc +12 -13
  107. data/src/core/ext/filters/client_channel/retry_service_config.h +10 -1
  108. data/src/core/ext/filters/client_channel/retry_throttle.cc +1 -8
  109. data/src/core/ext/filters/client_channel/retry_throttle.h +7 -1
  110. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +24 -6
  111. data/src/core/ext/filters/client_channel/subchannel.cc +186 -187
  112. data/src/core/ext/filters/client_channel/subchannel.h +80 -36
  113. data/src/core/ext/filters/client_channel/subchannel_interface.h +51 -41
  114. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +38 -0
  115. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +12 -2
  116. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +6 -3
  117. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +24 -95
  118. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +17 -9
  119. data/src/core/ext/filters/deadline/deadline_filter.cc +18 -9
  120. data/src/core/ext/filters/deadline/deadline_filter.h +8 -1
  121. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +22 -6
  122. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +8 -3
  123. data/src/core/ext/filters/fault_injection/service_config_parser.cc +7 -4
  124. data/src/core/ext/filters/fault_injection/service_config_parser.h +17 -3
  125. data/src/core/ext/filters/http/client/http_client_filter.cc +30 -10
  126. data/src/core/ext/filters/http/client/http_client_filter.h +15 -2
  127. data/src/core/ext/filters/http/client_authority_filter.cc +16 -20
  128. data/src/core/ext/filters/http/client_authority_filter.h +5 -2
  129. data/src/core/ext/filters/http/http_filters_plugin.cc +16 -9
  130. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +65 -187
  131. data/src/core/ext/filters/http/message_compress/message_compress_filter.h +1 -2
  132. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +45 -107
  133. data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +1 -0
  134. data/src/core/ext/filters/http/server/http_server_filter.cc +95 -255
  135. data/src/core/ext/filters/http/server/http_server_filter.h +37 -3
  136. data/src/core/ext/filters/message_size/message_size_filter.cc +45 -41
  137. data/src/core/ext/filters/message_size/message_size_filter.h +15 -2
  138. data/src/core/ext/filters/rbac/rbac_filter.cc +15 -3
  139. data/src/core/ext/filters/rbac/rbac_filter.h +8 -0
  140. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +13 -2
  141. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +14 -2
  142. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +1 -0
  143. data/src/core/ext/filters/server_config_selector/server_config_selector.h +9 -0
  144. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +22 -2
  145. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.h +1 -0
  146. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +104 -138
  147. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +9 -7
  148. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +58 -29
  149. data/src/core/ext/transport/chttp2/server/chttp2_server.h +2 -0
  150. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +3 -3
  151. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +2 -1
  152. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +1 -0
  153. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +260 -491
  154. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +6 -1
  155. data/src/core/ext/transport/chttp2/transport/context_list.cc +4 -0
  156. data/src/core/ext/transport/chttp2/transport/context_list.h +4 -1
  157. data/src/core/ext/transport/chttp2/transport/flow_control.cc +145 -261
  158. data/src/core/ext/transport/chttp2/transport/flow_control.h +179 -288
  159. data/src/core/ext/transport/chttp2/transport/frame.h +0 -4
  160. data/src/core/ext/transport/chttp2/transport/frame_data.cc +59 -211
  161. data/src/core/ext/transport/chttp2/transport/frame_data.h +13 -36
  162. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +3 -0
  163. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +3 -1
  164. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +5 -0
  165. data/src/core/ext/transport/chttp2/transport/frame_ping.h +3 -0
  166. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +6 -2
  167. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +3 -0
  168. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +10 -42
  169. data/src/core/ext/transport/chttp2/transport/frame_settings.h +4 -0
  170. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +10 -12
  171. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +3 -0
  172. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +14 -12
  173. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +15 -2
  174. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +3 -0
  175. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +3 -0
  176. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +32 -13
  177. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +8 -1
  178. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +53 -37
  179. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +38 -21
  180. data/src/core/ext/transport/chttp2/transport/http2_settings.h +0 -1
  181. data/src/core/ext/transport/chttp2/transport/internal.h +31 -112
  182. data/src/core/ext/transport/chttp2/transport/parsing.cc +77 -43
  183. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +11 -11
  184. data/src/core/ext/transport/chttp2/transport/stream_map.cc +1 -1
  185. data/src/core/ext/transport/chttp2/transport/stream_map.h +1 -0
  186. data/src/core/ext/transport/chttp2/transport/varint.h +2 -0
  187. data/src/core/ext/transport/chttp2/transport/writing.cc +54 -21
  188. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -1
  189. data/src/core/ext/transport/inproc/inproc_transport.cc +93 -86
  190. data/src/core/ext/transport/inproc/inproc_transport.h +3 -1
  191. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +52 -0
  192. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +164 -0
  193. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +46 -0
  194. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +94 -0
  195. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +47 -0
  196. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +109 -0
  197. data/src/core/ext/xds/certificate_provider_factory.h +6 -1
  198. data/src/core/ext/xds/certificate_provider_registry.cc +8 -8
  199. data/src/core/ext/xds/certificate_provider_registry.h +3 -1
  200. data/src/core/ext/xds/certificate_provider_store.cc +6 -2
  201. data/src/core/ext/xds/certificate_provider_store.h +10 -1
  202. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +9 -0
  203. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +8 -0
  204. data/src/core/ext/xds/upb_utils.h +1 -2
  205. data/src/core/ext/xds/xds_api.cc +16 -18
  206. data/src/core/ext/xds/xds_api.h +12 -5
  207. data/src/core/ext/xds/xds_bootstrap.cc +37 -24
  208. data/src/core/ext/xds/xds_bootstrap.h +9 -11
  209. data/src/core/ext/xds/xds_certificate_provider.cc +16 -4
  210. data/src/core/ext/xds/xds_certificate_provider.h +17 -2
  211. data/src/core/ext/xds/xds_channel_stack_modifier.cc +14 -5
  212. data/src/core/ext/xds/xds_channel_stack_modifier.h +5 -1
  213. data/src/core/ext/xds/xds_client.cc +117 -44
  214. data/src/core/ext/xds/xds_client.h +17 -3
  215. data/src/core/ext/xds/xds_client_stats.cc +3 -4
  216. data/src/core/ext/xds/xds_client_stats.h +4 -3
  217. data/src/core/ext/xds/xds_cluster.cc +126 -25
  218. data/src/core/ext/xds/xds_cluster.h +12 -1
  219. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +16 -7
  220. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +1 -8
  221. data/src/core/ext/xds/xds_common_types.cc +36 -22
  222. data/src/core/ext/xds/xds_common_types.h +12 -4
  223. data/src/core/ext/xds/xds_endpoint.cc +25 -15
  224. data/src/core/ext/xds/xds_endpoint.h +13 -5
  225. data/src/core/ext/xds/xds_http_fault_filter.cc +10 -8
  226. data/src/core/ext/xds/xds_http_fault_filter.h +3 -1
  227. data/src/core/ext/xds/xds_http_filters.cc +7 -0
  228. data/src/core/ext/xds/xds_http_filters.h +3 -3
  229. data/src/core/ext/xds/xds_http_rbac_filter.cc +16 -0
  230. data/src/core/ext/xds/xds_http_rbac_filter.h +7 -0
  231. data/src/core/ext/xds/xds_lb_policy_registry.cc +291 -0
  232. data/src/core/ext/xds/xds_lb_policy_registry.h +72 -0
  233. data/src/core/ext/xds/xds_listener.cc +70 -42
  234. data/src/core/ext/xds/xds_listener.h +10 -1
  235. data/src/core/ext/xds/xds_resource_type.h +3 -3
  236. data/src/core/ext/xds/xds_resource_type_impl.h +7 -3
  237. data/src/core/ext/xds/xds_route_config.cc +56 -28
  238. data/src/core/ext/xds/xds_route_config.h +11 -2
  239. data/src/core/ext/xds/xds_routing.cc +16 -0
  240. data/src/core/ext/xds/xds_routing.h +7 -2
  241. data/src/core/ext/xds/xds_server_config_fetcher.cc +56 -7
  242. data/src/core/lib/address_utils/parse_address.cc +5 -8
  243. data/src/core/lib/address_utils/parse_address.h +3 -2
  244. data/src/core/lib/address_utils/sockaddr_utils.cc +60 -26
  245. data/src/core/lib/address_utils/sockaddr_utils.h +9 -4
  246. data/src/core/lib/avl/avl.h +6 -4
  247. data/src/core/lib/backoff/backoff.cc +1 -1
  248. data/src/core/lib/backoff/backoff.h +1 -1
  249. data/src/core/lib/channel/call_finalization.h +4 -0
  250. data/src/core/lib/channel/call_tracer.h +11 -5
  251. data/src/core/lib/channel/channel_args.cc +41 -22
  252. data/src/core/lib/channel/channel_args.h +34 -3
  253. data/src/core/lib/channel/channel_args_preconditioning.cc +4 -3
  254. data/src/core/lib/channel/channel_args_preconditioning.h +3 -2
  255. data/src/core/lib/channel/channel_fwd.h +26 -0
  256. data/src/core/lib/channel/channel_stack.cc +45 -7
  257. data/src/core/lib/channel/channel_stack.h +45 -9
  258. data/src/core/lib/channel/channel_stack_builder.cc +9 -19
  259. data/src/core/lib/channel/channel_stack_builder.h +17 -32
  260. data/src/core/lib/channel/channel_stack_builder_impl.cc +38 -43
  261. data/src/core/lib/channel/channel_stack_builder_impl.h +4 -6
  262. data/src/core/lib/channel/channel_trace.cc +8 -13
  263. data/src/core/lib/channel/channel_trace.h +6 -3
  264. data/src/core/lib/channel/channelz.cc +10 -14
  265. data/src/core/lib/channel/channelz.h +15 -7
  266. data/src/core/lib/channel/channelz_registry.cc +11 -19
  267. data/src/core/lib/channel/channelz_registry.h +10 -9
  268. data/src/core/lib/channel/connected_channel.cc +22 -31
  269. data/src/core/lib/channel/connected_channel.h +2 -0
  270. data/src/core/lib/channel/promise_based_filter.cc +451 -190
  271. data/src/core/lib/channel/promise_based_filter.h +162 -27
  272. data/src/core/lib/channel/status_util.cc +2 -0
  273. data/src/core/lib/channel/status_util.h +0 -3
  274. data/src/core/lib/compression/compression.cc +6 -1
  275. data/src/core/lib/compression/compression_internal.cc +48 -16
  276. data/src/core/lib/compression/compression_internal.h +4 -3
  277. data/src/core/lib/compression/message_compress.cc +3 -1
  278. data/src/core/lib/compression/message_compress.h +2 -3
  279. data/src/core/lib/config/core_configuration.cc +3 -0
  280. data/src/core/lib/config/core_configuration.h +2 -1
  281. data/src/core/lib/debug/stats.cc +9 -9
  282. data/src/core/lib/debug/stats.h +2 -1
  283. data/src/core/lib/debug/stats_data.cc +2 -1
  284. data/src/core/lib/debug/stats_data.h +0 -4
  285. data/src/core/lib/debug/trace.h +13 -12
  286. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +4 -2
  287. data/src/core/lib/event_engine/channel_args_endpoint_config.h +3 -2
  288. data/src/core/lib/event_engine/default_event_engine_factory.cc +8 -2
  289. data/src/core/lib/event_engine/event_engine.cc +29 -14
  290. data/src/core/lib/event_engine/event_engine_factory.h +5 -0
  291. data/src/core/lib/event_engine/handle_containers.h +67 -0
  292. data/src/core/lib/event_engine/iomgr_engine/iomgr_engine.cc +159 -0
  293. data/src/core/lib/event_engine/iomgr_engine/iomgr_engine.h +122 -0
  294. data/src/core/lib/event_engine/iomgr_engine/thread_pool.cc +123 -0
  295. data/src/core/lib/event_engine/iomgr_engine/thread_pool.h +70 -0
  296. data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.cc +62 -0
  297. data/src/core/lib/event_engine/iomgr_engine/time_averaged_stats.h +81 -0
  298. data/src/core/lib/event_engine/iomgr_engine/timer.cc +312 -0
  299. data/src/core/lib/event_engine/iomgr_engine/timer.h +193 -0
  300. data/src/core/lib/event_engine/iomgr_engine/timer_heap.cc +107 -0
  301. data/src/core/lib/event_engine/iomgr_engine/timer_heap.h +56 -0
  302. data/src/core/lib/event_engine/iomgr_engine/timer_manager.cc +254 -0
  303. data/src/core/lib/event_engine/iomgr_engine/timer_manager.h +111 -0
  304. data/src/core/lib/event_engine/memory_allocator.cc +12 -4
  305. data/src/core/lib/{iomgr/event_engine → event_engine}/promise.h +27 -9
  306. data/src/core/lib/event_engine/resolved_address.cc +4 -2
  307. data/src/core/lib/event_engine/slice.cc +102 -0
  308. data/src/core/lib/event_engine/slice_buffer.cc +50 -0
  309. data/src/core/lib/{iomgr/event_engine/pollset.h → event_engine/trace.cc} +3 -10
  310. data/src/core/lib/{iomgr/endpoint_pair_event_engine.cc → event_engine/trace.h} +12 -14
  311. data/src/core/lib/gpr/log.cc +5 -0
  312. data/src/core/lib/gpr/time_posix.cc +6 -9
  313. data/src/core/lib/gpr/time_windows.cc +10 -7
  314. data/src/core/lib/gpr/tls.h +3 -5
  315. data/src/core/lib/gprpp/bitset.h +5 -1
  316. data/src/core/lib/gprpp/chunked_vector.h +4 -0
  317. data/src/core/lib/gprpp/construct_destruct.h +1 -0
  318. data/src/core/lib/gprpp/dual_ref_counted.h +1 -4
  319. data/src/core/lib/gprpp/examine_stack.h +0 -1
  320. data/src/core/lib/gprpp/fork.cc +3 -6
  321. data/src/core/lib/gprpp/global_config.h +2 -4
  322. data/src/core/lib/gprpp/global_config_env.cc +3 -2
  323. data/src/core/lib/gprpp/global_config_env.h +3 -1
  324. data/src/core/lib/gprpp/global_config_generic.h +0 -4
  325. data/src/core/lib/gprpp/host_port.cc +2 -0
  326. data/src/core/lib/gprpp/manual_constructor.h +0 -68
  327. data/src/core/lib/gprpp/match.h +2 -0
  328. data/src/core/lib/gprpp/memory.h +1 -5
  329. data/src/core/lib/gprpp/orphanable.h +1 -4
  330. data/src/core/lib/gprpp/ref_counted.h +1 -3
  331. data/src/core/lib/gprpp/ref_counted_ptr.h +1 -1
  332. data/src/core/lib/gprpp/stat.h +0 -2
  333. data/src/core/lib/gprpp/stat_posix.cc +7 -2
  334. data/src/core/lib/gprpp/status_helper.cc +50 -32
  335. data/src/core/lib/gprpp/status_helper.h +4 -0
  336. data/src/core/lib/gprpp/sync.h +3 -1
  337. data/src/core/lib/gprpp/table.h +10 -0
  338. data/src/core/lib/gprpp/thd.h +2 -5
  339. data/src/core/lib/gprpp/thd_posix.cc +4 -2
  340. data/src/core/lib/gprpp/thd_windows.cc +2 -0
  341. data/src/core/lib/gprpp/time.cc +16 -0
  342. data/src/core/lib/gprpp/time.h +10 -1
  343. data/src/core/lib/gprpp/time_util.cc +4 -0
  344. data/src/core/lib/gprpp/time_util.h +1 -1
  345. data/src/core/lib/gprpp/unique_type_name.h +104 -0
  346. data/src/core/lib/http/format_request.cc +34 -4
  347. data/src/core/lib/http/format_request.h +3 -1
  348. data/src/core/lib/http/httpcli.cc +106 -93
  349. data/src/core/lib/http/httpcli.h +58 -10
  350. data/src/core/lib/http/httpcli_security_connector.cc +19 -8
  351. data/src/core/lib/http/httpcli_ssl_credentials.h +3 -1
  352. data/src/core/lib/http/parser.cc +6 -7
  353. data/src/core/lib/http/parser.h +3 -0
  354. data/src/core/lib/iomgr/call_combiner.cc +2 -2
  355. data/src/core/lib/iomgr/endpoint.cc +4 -4
  356. data/src/core/lib/iomgr/endpoint.h +7 -5
  357. data/src/core/lib/iomgr/endpoint_cfstream.cc +9 -6
  358. data/src/core/lib/iomgr/endpoint_pair_posix.cc +2 -1
  359. data/src/core/lib/iomgr/error.cc +11 -9
  360. data/src/core/lib/iomgr/error.h +9 -5
  361. data/src/core/lib/iomgr/ev_epoll1_linux.cc +57 -18
  362. data/src/core/lib/iomgr/ev_epoll1_linux.h +1 -1
  363. data/src/core/lib/iomgr/ev_poll_posix.cc +77 -52
  364. data/src/core/lib/iomgr/ev_poll_posix.h +2 -2
  365. data/src/core/lib/iomgr/ev_posix.cc +55 -96
  366. data/src/core/lib/iomgr/ev_posix.h +5 -3
  367. data/src/core/lib/iomgr/exec_ctx.h +1 -2
  368. data/src/core/lib/iomgr/fork_posix.cc +1 -1
  369. data/src/core/lib/iomgr/internal_errqueue.cc +38 -47
  370. data/src/core/lib/iomgr/internal_errqueue.h +1 -6
  371. data/src/core/lib/iomgr/iomgr.cc +7 -1
  372. data/src/core/{ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_event_engine.cc → lib/iomgr/iomgr_fwd.h} +9 -12
  373. data/src/core/lib/iomgr/iomgr_posix.cc +1 -0
  374. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +1 -0
  375. data/src/core/lib/iomgr/load_file.cc +1 -1
  376. data/src/core/lib/iomgr/pollset_set.h +1 -2
  377. data/src/core/lib/iomgr/port.h +25 -6
  378. data/src/core/lib/iomgr/resolve_address.cc +8 -0
  379. data/src/core/lib/iomgr/resolve_address.h +21 -14
  380. data/src/core/lib/iomgr/resolve_address_impl.h +2 -3
  381. data/src/core/lib/iomgr/resolve_address_posix.cc +9 -15
  382. data/src/core/lib/iomgr/resolve_address_posix.h +5 -2
  383. data/src/core/lib/iomgr/resolve_address_windows.cc +8 -15
  384. data/src/core/lib/iomgr/resolve_address_windows.h +5 -2
  385. data/src/core/lib/iomgr/sockaddr.h +2 -3
  386. data/src/core/lib/iomgr/sockaddr_posix.h +2 -0
  387. data/src/core/lib/iomgr/sockaddr_windows.h +2 -0
  388. data/src/core/lib/iomgr/socket_utils_common_posix.cc +3 -2
  389. data/src/core/lib/iomgr/tcp_client.cc +12 -7
  390. data/src/core/lib/iomgr/tcp_client.h +24 -13
  391. data/src/core/lib/iomgr/tcp_client_cfstream.cc +24 -10
  392. data/src/core/lib/iomgr/tcp_client_posix.cc +154 -29
  393. data/src/core/lib/iomgr/tcp_client_posix.h +1 -1
  394. data/src/core/lib/iomgr/tcp_client_windows.cc +27 -16
  395. data/src/core/lib/iomgr/tcp_posix.cc +96 -52
  396. data/src/core/lib/iomgr/tcp_server_posix.cc +33 -19
  397. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +41 -38
  398. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +9 -6
  399. data/src/core/lib/iomgr/tcp_server_windows.cc +20 -12
  400. data/src/core/lib/iomgr/tcp_windows.cc +12 -9
  401. data/src/core/lib/iomgr/unix_sockets_posix.cc +2 -2
  402. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +2 -2
  403. data/src/core/lib/iomgr/wakeup_fd_posix.cc +15 -12
  404. data/src/core/lib/iomgr/wakeup_fd_posix.h +0 -2
  405. data/src/core/lib/iomgr/work_serializer.h +2 -3
  406. data/src/core/lib/json/json.h +1 -2
  407. data/src/core/lib/json/json_reader.cc +9 -1
  408. data/src/core/lib/json/json_util.cc +7 -0
  409. data/src/core/lib/json/json_util.h +10 -1
  410. data/src/core/lib/json/json_writer.cc +6 -1
  411. data/src/core/lib/matchers/matchers.cc +6 -3
  412. data/src/core/lib/matchers/matchers.h +2 -0
  413. data/src/core/lib/promise/activity.cc +1 -2
  414. data/src/core/lib/promise/activity.h +13 -19
  415. data/src/core/lib/promise/arena_promise.h +11 -1
  416. data/src/core/lib/promise/call_push_pull.h +4 -0
  417. data/src/core/lib/promise/context.h +1 -1
  418. data/src/core/lib/promise/detail/basic_seq.h +2 -2
  419. data/src/core/lib/promise/detail/promise_factory.h +0 -1
  420. data/src/core/lib/promise/latch.h +0 -1
  421. data/src/core/lib/promise/loop.h +2 -0
  422. data/src/core/lib/promise/promise.h +1 -0
  423. data/src/core/lib/promise/race.h +0 -1
  424. data/src/core/lib/promise/seq.h +0 -2
  425. data/src/core/lib/promise/sleep.cc +38 -31
  426. data/src/core/lib/promise/sleep.h +32 -22
  427. data/src/core/lib/promise/try_seq.h +2 -2
  428. data/src/core/lib/resolver/resolver.cc +5 -0
  429. data/src/core/lib/resolver/resolver.h +3 -0
  430. data/src/core/lib/resolver/resolver_factory.h +6 -4
  431. data/src/core/lib/resolver/resolver_registry.cc +2 -9
  432. data/src/core/lib/resolver/resolver_registry.h +12 -1
  433. data/src/core/lib/resolver/server_address.cc +17 -3
  434. data/src/core/lib/resolver/server_address.h +13 -6
  435. data/src/core/lib/resource_quota/api.cc +14 -1
  436. data/src/core/lib/resource_quota/api.h +4 -1
  437. data/src/core/lib/resource_quota/arena.cc +0 -6
  438. data/src/core/lib/resource_quota/arena.h +1 -2
  439. data/src/core/lib/resource_quota/memory_quota.cc +62 -62
  440. data/src/core/lib/resource_quota/memory_quota.h +35 -30
  441. data/src/core/lib/resource_quota/resource_quota.h +8 -0
  442. data/src/core/lib/resource_quota/thread_quota.cc +2 -0
  443. data/src/core/lib/resource_quota/thread_quota.h +4 -0
  444. data/src/core/lib/security/authorization/authorization_policy_provider.h +7 -0
  445. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +4 -0
  446. data/src/core/lib/security/authorization/evaluate_args.cc +9 -3
  447. data/src/core/lib/security/authorization/evaluate_args.h +6 -3
  448. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +6 -0
  449. data/src/core/lib/security/authorization/grpc_authorization_engine.h +7 -0
  450. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +15 -0
  451. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +12 -1
  452. data/src/core/lib/security/authorization/matchers.cc +9 -1
  453. data/src/core/lib/security/authorization/matchers.h +7 -0
  454. data/src/core/lib/security/authorization/rbac_policy.cc +5 -0
  455. data/src/core/lib/security/authorization/rbac_policy.h +7 -0
  456. data/src/core/lib/security/context/security_context.cc +5 -2
  457. data/src/core/lib/security/context/security_context.h +14 -2
  458. data/src/core/lib/security/credentials/alts/alts_credentials.cc +12 -4
  459. data/src/core/lib/security/credentials/alts/alts_credentials.h +8 -3
  460. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +1 -3
  461. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +1 -4
  462. data/src/core/lib/security/credentials/call_creds_util.cc +10 -0
  463. data/src/core/lib/security/credentials/call_creds_util.h +1 -0
  464. data/src/core/lib/security/credentials/channel_creds_registry.h +7 -1
  465. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +10 -0
  466. data/src/core/lib/security/credentials/composite/composite_credentials.cc +11 -7
  467. data/src/core/lib/security/credentials/composite/composite_credentials.h +21 -6
  468. data/src/core/lib/security/credentials/credentials.cc +4 -8
  469. data/src/core/lib/security/credentials/credentials.h +27 -18
  470. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +108 -9
  471. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +18 -0
  472. data/src/core/lib/security/credentials/external/aws_request_signer.cc +9 -0
  473. data/src/core/lib/security/credentials/external/external_account_credentials.cc +27 -9
  474. data/src/core/lib/security/credentials/external/external_account_credentials.h +11 -0
  475. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +12 -4
  476. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +6 -0
  477. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +22 -4
  478. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +10 -0
  479. data/src/core/lib/security/credentials/fake/fake_credentials.cc +21 -9
  480. data/src/core/lib/security/credentials/fake/fake_credentials.h +15 -3
  481. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +1 -0
  482. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +51 -24
  483. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +12 -3
  484. data/src/core/lib/security/credentials/iam/iam_credentials.cc +13 -4
  485. data/src/core/lib/security/credentials/iam/iam_credentials.h +12 -2
  486. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +12 -2
  487. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +9 -4
  488. data/src/core/lib/security/credentials/jwt/json_token.cc +5 -2
  489. data/src/core/lib/security/credentials/jwt/json_token.h +2 -2
  490. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +14 -7
  491. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +16 -2
  492. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +28 -3
  493. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +4 -2
  494. data/src/core/lib/security/credentials/local/local_credentials.cc +12 -5
  495. data/src/core/lib/security/credentials/local/local_credentials.h +9 -2
  496. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +36 -19
  497. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +24 -4
  498. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +12 -8
  499. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +25 -1
  500. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +13 -2
  501. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +17 -4
  502. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +6 -6
  503. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +9 -3
  504. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +39 -10
  505. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +14 -11
  506. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +35 -3
  507. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +34 -11
  508. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +4 -5
  509. data/src/core/lib/security/credentials/tls/tls_credentials.cc +17 -2
  510. data/src/core/lib/security/credentials/tls/tls_credentials.h +7 -3
  511. data/src/core/lib/security/credentials/tls/tls_utils.cc +2 -0
  512. data/src/core/lib/security/credentials/tls/tls_utils.h +1 -1
  513. data/src/core/lib/security/credentials/xds/xds_credentials.cc +20 -4
  514. data/src/core/lib/security/credentials/xds/xds_credentials.h +19 -5
  515. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +22 -2
  516. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +6 -3
  517. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +18 -2
  518. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +2 -2
  519. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +9 -0
  520. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +17 -2
  521. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +5 -3
  522. data/src/core/lib/security/security_connector/{load_system_roots_linux.cc → load_system_roots_supported.cc} +27 -19
  523. data/src/core/lib/security/security_connector/{load_system_roots_linux.h → load_system_roots_supported.h} +5 -5
  524. data/src/core/lib/security/security_connector/local/local_security_connector.cc +22 -3
  525. data/src/core/lib/security/security_connector/local/local_security_connector.h +6 -2
  526. data/src/core/lib/security/security_connector/security_connector.cc +20 -18
  527. data/src/core/lib/security/security_connector/security_connector.h +19 -7
  528. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +19 -7
  529. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +4 -2
  530. data/src/core/lib/security/security_connector/ssl_utils.cc +12 -2
  531. data/src/core/lib/security/security_connector/ssl_utils.h +10 -7
  532. data/src/core/lib/security/security_connector/ssl_utils_config.h +1 -1
  533. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +21 -13
  534. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +23 -3
  535. data/src/core/lib/security/transport/auth_filters.h +7 -0
  536. data/src/core/lib/security/transport/client_auth_filter.cc +24 -17
  537. data/src/core/lib/security/transport/secure_endpoint.cc +81 -20
  538. data/src/core/lib/security/transport/secure_endpoint.h +4 -3
  539. data/src/core/lib/security/transport/security_handshaker.cc +49 -16
  540. data/src/core/lib/security/transport/security_handshaker.h +5 -1
  541. data/src/core/lib/security/transport/server_auth_filter.cc +29 -6
  542. data/src/core/lib/security/util/json_util.cc +3 -2
  543. data/src/core/lib/security/util/json_util.h +0 -2
  544. data/src/core/lib/service_config/service_config.h +4 -8
  545. data/src/core/lib/service_config/service_config_call_data.h +6 -2
  546. data/src/core/lib/service_config/service_config_impl.cc +13 -6
  547. data/src/core/lib/service_config/service_config_impl.h +9 -4
  548. data/src/core/lib/service_config/service_config_parser.cc +8 -2
  549. data/src/core/lib/service_config/service_config_parser.h +7 -0
  550. data/src/core/lib/slice/b64.cc +1 -1
  551. data/src/core/lib/slice/b64.h +2 -0
  552. data/src/core/lib/slice/percent_encoding.cc +4 -1
  553. data/src/core/lib/slice/percent_encoding.h +0 -6
  554. data/src/core/lib/slice/slice.cc +2 -1
  555. data/src/core/lib/slice/slice.h +10 -5
  556. data/src/core/lib/slice/slice_api.cc +1 -1
  557. data/src/core/lib/slice/slice_buffer.cc +79 -23
  558. data/src/core/lib/slice/slice_buffer.h +137 -0
  559. data/src/core/lib/slice/slice_buffer_api.cc +35 -0
  560. data/src/core/lib/slice/slice_internal.h +4 -3
  561. data/src/core/lib/slice/slice_refcount.h +2 -3
  562. data/src/core/lib/slice/slice_refcount_base.h +2 -3
  563. data/src/core/lib/slice/slice_string_helpers.cc +0 -16
  564. data/src/core/lib/slice/slice_string_helpers.h +1 -8
  565. data/src/core/lib/surface/builtins.cc +7 -2
  566. data/src/core/lib/surface/byte_buffer.cc +7 -1
  567. data/src/core/lib/surface/byte_buffer_reader.cc +4 -4
  568. data/src/core/lib/surface/call.cc +90 -137
  569. data/src/core/lib/surface/call.h +21 -3
  570. data/src/core/lib/surface/call_details.cc +4 -4
  571. data/src/core/lib/surface/call_log_batch.cc +7 -1
  572. data/src/core/lib/surface/call_test_only.h +4 -1
  573. data/src/core/lib/surface/channel.cc +179 -242
  574. data/src/core/lib/surface/channel.h +97 -58
  575. data/src/core/lib/surface/channel_init.h +2 -0
  576. data/src/core/lib/surface/channel_ping.cc +8 -2
  577. data/src/core/lib/surface/channel_stack_type.cc +0 -2
  578. data/src/core/lib/surface/channel_stack_type.h +0 -2
  579. data/src/core/lib/surface/completion_queue.cc +29 -20
  580. data/src/core/lib/surface/completion_queue.h +7 -2
  581. data/src/core/lib/surface/completion_queue_factory.cc +1 -0
  582. data/src/core/lib/surface/completion_queue_factory.h +1 -3
  583. data/src/core/lib/surface/event_string.cc +1 -7
  584. data/src/core/lib/surface/event_string.h +1 -1
  585. data/src/core/lib/surface/init.cc +17 -46
  586. data/src/core/lib/surface/init.h +0 -8
  587. data/src/core/lib/surface/lame_client.cc +63 -109
  588. data/src/core/lib/surface/lame_client.h +41 -3
  589. data/src/core/lib/surface/metadata_array.cc +2 -0
  590. data/src/core/lib/surface/server.cc +83 -64
  591. data/src/core/lib/surface/server.h +42 -9
  592. data/src/core/lib/surface/validate_metadata.cc +3 -6
  593. data/src/core/lib/surface/validate_metadata.h +3 -0
  594. data/src/core/lib/surface/version.cc +2 -2
  595. data/src/core/lib/transport/bdp_estimator.cc +3 -1
  596. data/src/core/lib/transport/bdp_estimator.h +2 -3
  597. data/src/core/lib/transport/connectivity_state.cc +6 -4
  598. data/src/core/lib/transport/connectivity_state.h +2 -3
  599. data/src/core/lib/transport/error_utils.cc +16 -8
  600. data/src/core/lib/transport/error_utils.h +5 -1
  601. data/src/core/lib/{channel → transport}/handshaker.cc +12 -7
  602. data/src/core/lib/{channel → transport}/handshaker.h +13 -6
  603. data/src/core/lib/{channel → transport}/handshaker_factory.h +9 -10
  604. data/src/core/lib/{channel → transport}/handshaker_registry.cc +5 -1
  605. data/src/core/lib/{channel → transport}/handshaker_registry.h +5 -4
  606. data/src/core/{ext/filters/client_channel → lib/transport}/http_connect_handshaker.cc +28 -14
  607. data/src/core/{ext/filters/client_channel → lib/transport}/http_connect_handshaker.h +3 -3
  608. data/src/core/lib/transport/metadata_batch.cc +287 -0
  609. data/src/core/lib/transport/metadata_batch.h +133 -264
  610. data/src/core/lib/transport/parsed_metadata.cc +2 -0
  611. data/src/core/lib/transport/parsed_metadata.h +10 -3
  612. data/src/core/lib/transport/status_conversion.cc +2 -0
  613. data/src/core/lib/transport/status_conversion.h +2 -2
  614. data/src/core/lib/transport/tcp_connect_handshaker.cc +253 -0
  615. data/src/core/lib/transport/tcp_connect_handshaker.h +39 -0
  616. data/src/core/lib/transport/timeout_encoding.cc +2 -6
  617. data/src/core/lib/transport/timeout_encoding.h +5 -1
  618. data/src/core/lib/transport/transport.cc +18 -20
  619. data/src/core/lib/transport/transport.h +48 -16
  620. data/src/core/lib/transport/transport_fwd.h +20 -0
  621. data/src/core/lib/transport/transport_impl.h +11 -0
  622. data/src/core/lib/transport/transport_op_string.cc +17 -18
  623. data/src/core/lib/uri/uri_parser.cc +11 -3
  624. data/src/core/lib/uri/uri_parser.h +0 -2
  625. data/src/core/plugin_registry/grpc_plugin_registry.cc +11 -0
  626. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +1 -1
  627. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +9 -1
  628. data/src/core/tsi/fake_transport_security.cc +13 -1
  629. data/src/core/tsi/fake_transport_security.h +6 -0
  630. data/src/core/tsi/ssl/session_cache/ssl_session.h +2 -0
  631. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +2 -0
  632. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +2 -0
  633. data/src/core/tsi/ssl_transport_security.cc +1 -1
  634. data/src/core/tsi/transport_security_grpc.cc +3 -2
  635. data/src/core/tsi/transport_security_grpc.h +5 -2
  636. data/src/ruby/ext/grpc/ext-export-truffleruby.clang +2 -0
  637. data/src/ruby/ext/grpc/ext-export-truffleruby.gcc +7 -0
  638. data/src/ruby/ext/grpc/ext-export.clang +1 -0
  639. data/src/ruby/ext/grpc/ext-export.gcc +1 -0
  640. data/src/ruby/ext/grpc/extconf.rb +50 -19
  641. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +1 -1
  642. data/src/ruby/lib/grpc/2.5/grpc_c.so +0 -0
  643. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  644. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  645. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  646. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  647. data/src/ruby/lib/grpc/errors.rb +1 -1
  648. data/src/ruby/lib/grpc/grpc_c.so +0 -0
  649. data/src/ruby/lib/grpc/version.rb +1 -1
  650. data/src/ruby/spec/generic/client_stub_spec.rb +23 -23
  651. data/third_party/abseil-cpp/absl/algorithm/container.h +1 -1
  652. data/third_party/abseil-cpp/absl/base/attributes.h +49 -22
  653. data/third_party/abseil-cpp/absl/base/casts.h +61 -68
  654. data/third_party/abseil-cpp/absl/base/config.h +182 -41
  655. data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +12 -42
  656. data/third_party/abseil-cpp/absl/base/internal/cycleclock.h +67 -2
  657. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +3 -3
  658. data/third_party/abseil-cpp/absl/base/internal/endian.h +17 -62
  659. data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +2 -0
  660. data/third_party/abseil-cpp/absl/base/internal/invoke.h +54 -0
  661. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +138 -0
  662. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +29 -22
  663. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +13 -12
  664. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +3 -0
  665. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +8 -0
  666. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +2 -5
  667. data/third_party/abseil-cpp/absl/base/internal/strerror.cc +88 -0
  668. data/third_party/abseil-cpp/absl/base/internal/strerror.h +39 -0
  669. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +0 -1
  670. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +2 -1
  671. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +6 -7
  672. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +12 -3
  673. data/third_party/abseil-cpp/absl/base/log_severity.cc +28 -0
  674. data/third_party/abseil-cpp/absl/base/log_severity.h +51 -0
  675. data/third_party/abseil-cpp/absl/base/optimization.h +19 -11
  676. data/third_party/abseil-cpp/absl/base/options.h +1 -1
  677. data/third_party/abseil-cpp/absl/base/thread_annotations.h +2 -2
  678. data/third_party/abseil-cpp/absl/container/fixed_array.h +2 -0
  679. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +11 -4
  680. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +510 -0
  681. data/third_party/abseil-cpp/absl/container/inlined_vector.h +20 -9
  682. data/third_party/abseil-cpp/absl/container/internal/common.h +6 -5
  683. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +10 -28
  684. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +68 -20
  685. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +29 -11
  686. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +59 -38
  687. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +4 -0
  688. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +515 -184
  689. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +45 -88
  690. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +4 -0
  691. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +3 -2
  692. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +8 -3
  693. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +8 -3
  694. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +2 -1
  695. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +8 -3
  696. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +20 -18
  697. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +8 -3
  698. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +15 -2
  699. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +6 -1
  700. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +46 -7
  701. data/third_party/abseil-cpp/absl/functional/bind_front.h +10 -1
  702. data/third_party/abseil-cpp/absl/functional/function_ref.h +2 -1
  703. data/third_party/abseil-cpp/absl/hash/hash.h +82 -8
  704. data/third_party/abseil-cpp/absl/hash/internal/hash.h +218 -23
  705. data/third_party/abseil-cpp/absl/numeric/bits.h +2 -1
  706. data/third_party/abseil-cpp/absl/numeric/int128.cc +4 -2
  707. data/third_party/abseil-cpp/absl/numeric/int128.h +2 -2
  708. data/third_party/abseil-cpp/absl/profiling/internal/sample_recorder.h +21 -6
  709. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +4 -4
  710. data/third_party/abseil-cpp/absl/random/distributions.h +3 -3
  711. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +3 -0
  712. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +2 -1
  713. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +2 -2
  714. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +59 -48
  715. data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +1 -1
  716. data/third_party/abseil-cpp/absl/random/internal/randen.h +5 -11
  717. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +6 -2
  718. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +48 -23
  719. data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +24 -26
  720. data/third_party/abseil-cpp/absl/random/internal/traits.h +53 -5
  721. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +5 -5
  722. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +33 -48
  723. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +9 -10
  724. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +7 -4
  725. data/third_party/abseil-cpp/absl/random/seed_sequences.h +1 -0
  726. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +2 -2
  727. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +1 -1
  728. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +4 -3
  729. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +17 -0
  730. data/third_party/abseil-cpp/absl/status/status.cc +174 -2
  731. data/third_party/abseil-cpp/absl/status/status.h +22 -12
  732. data/third_party/abseil-cpp/absl/status/statusor.h +9 -3
  733. data/third_party/abseil-cpp/absl/strings/ascii.h +4 -4
  734. data/third_party/abseil-cpp/absl/strings/cord.cc +194 -913
  735. data/third_party/abseil-cpp/absl/strings/cord.h +202 -81
  736. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +188 -0
  737. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +44 -0
  738. data/third_party/abseil-cpp/absl/strings/cord_buffer.cc +30 -0
  739. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +572 -0
  740. data/third_party/abseil-cpp/absl/strings/internal/cord_data_edge.h +63 -0
  741. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +20 -32
  742. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +123 -88
  743. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +149 -49
  744. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +44 -59
  745. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +3 -1
  746. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +4 -2
  747. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +3 -2
  748. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +5 -4
  749. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +7 -74
  750. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +54 -0
  751. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.h +102 -0
  752. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +58 -17
  753. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +13 -11
  754. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +11 -38
  755. data/third_party/abseil-cpp/absl/strings/internal/cordz_statistics.h +1 -0
  756. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +4 -2
  757. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +6 -5
  758. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.cc +1 -1
  759. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +1 -1
  760. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +1 -1
  761. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +38 -7
  762. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +7 -2
  763. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +4 -5
  764. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +5 -2
  765. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +2 -1
  766. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +4 -2
  767. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +9 -6
  768. data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +10 -2
  769. data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +9 -9
  770. data/third_party/abseil-cpp/absl/strings/numbers.cc +8 -8
  771. data/third_party/abseil-cpp/absl/strings/numbers.h +26 -23
  772. data/third_party/abseil-cpp/absl/strings/str_cat.h +20 -13
  773. data/third_party/abseil-cpp/absl/strings/str_join.h +9 -15
  774. data/third_party/abseil-cpp/absl/strings/str_split.h +1 -2
  775. data/third_party/abseil-cpp/absl/strings/string_view.cc +2 -13
  776. data/third_party/abseil-cpp/absl/strings/string_view.h +3 -2
  777. data/third_party/abseil-cpp/absl/strings/strip.h +8 -6
  778. data/third_party/abseil-cpp/absl/strings/substitute.h +10 -2
  779. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +9 -6
  780. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -4
  781. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -4
  782. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +1 -6
  783. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -25
  784. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +10 -4
  785. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +75 -40
  786. data/third_party/abseil-cpp/absl/synchronization/mutex.h +17 -9
  787. data/third_party/abseil-cpp/absl/synchronization/notification.h +3 -2
  788. data/third_party/abseil-cpp/absl/time/duration.cc +5 -4
  789. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +11 -7
  790. data/third_party/abseil-cpp/absl/time/time.h +16 -12
  791. data/third_party/abseil-cpp/absl/types/internal/optional.h +8 -0
  792. data/third_party/abseil-cpp/absl/types/internal/variant.h +3 -3
  793. data/third_party/abseil-cpp/absl/types/optional.h +17 -14
  794. data/third_party/abseil-cpp/absl/types/span.h +2 -1
  795. metadata +67 -36
  796. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_event_engine.cc +0 -31
  797. data/src/core/lib/event_engine/sockaddr.cc +0 -40
  798. data/src/core/lib/event_engine/sockaddr.h +0 -44
  799. data/src/core/lib/gprpp/capture.h +0 -76
  800. data/src/core/lib/iomgr/event_engine/closure.cc +0 -77
  801. data/src/core/lib/iomgr/event_engine/closure.h +0 -42
  802. data/src/core/lib/iomgr/event_engine/endpoint.cc +0 -172
  803. data/src/core/lib/iomgr/event_engine/endpoint.h +0 -52
  804. data/src/core/lib/iomgr/event_engine/iomgr.cc +0 -85
  805. data/src/core/lib/iomgr/event_engine/pollset.cc +0 -87
  806. data/src/core/lib/iomgr/event_engine/resolved_address_internal.cc +0 -47
  807. data/src/core/lib/iomgr/event_engine/resolved_address_internal.h +0 -37
  808. data/src/core/lib/iomgr/event_engine/resolver.cc +0 -133
  809. data/src/core/lib/iomgr/event_engine/resolver.h +0 -56
  810. data/src/core/lib/iomgr/event_engine/tcp.cc +0 -296
  811. data/src/core/lib/iomgr/event_engine/timer.cc +0 -62
  812. data/src/core/lib/slice/slice_split.cc +0 -100
  813. data/src/core/lib/slice/slice_split.h +0 -40
  814. data/src/core/lib/transport/byte_stream.cc +0 -164
  815. data/src/core/lib/transport/byte_stream.h +0 -166
  816. data/third_party/abseil-cpp/absl/container/internal/have_sse.h +0 -50
@@ -20,49 +20,74 @@
20
20
 
21
21
  #include "src/core/ext/transport/chttp2/client/chttp2_connector.h"
22
22
 
23
- #include <string.h>
23
+ #include <stdint.h>
24
+
25
+ #include <string>
26
+
27
+ #include "absl/container/inlined_vector.h"
28
+ #include "absl/status/status.h"
29
+ #include "absl/status/statusor.h"
24
30
 
25
31
  #include <grpc/grpc.h>
26
32
  #include <grpc/grpc_posix.h>
27
- #include <grpc/slice_buffer.h>
33
+ #include <grpc/grpc_security.h>
34
+ #include <grpc/impl/codegen/grpc_types.h>
35
+ #include <grpc/status.h>
28
36
  #include <grpc/support/alloc.h>
29
- #include <grpc/support/string_util.h>
37
+ #include <grpc/support/log.h>
38
+ #include <grpc/support/sync.h>
30
39
 
31
40
  #include "src/core/ext/filters/client_channel/client_channel.h"
41
+ #include "src/core/ext/filters/client_channel/client_channel_factory.h"
32
42
  #include "src/core/ext/filters/client_channel/connector.h"
43
+ #include "src/core/ext/filters/client_channel/subchannel.h"
33
44
  #include "src/core/ext/transport/chttp2/transport/chttp2_transport.h"
34
45
  #include "src/core/lib/address_utils/sockaddr_utils.h"
35
46
  #include "src/core/lib/channel/channel_args.h"
36
- #include "src/core/lib/channel/handshaker.h"
47
+ #include "src/core/lib/channel/channel_args_preconditioning.h"
48
+ #include "src/core/lib/channel/channelz.h"
37
49
  #include "src/core/lib/config/core_configuration.h"
38
- #include "src/core/lib/gprpp/memory.h"
50
+ #include "src/core/lib/debug/trace.h"
51
+ #include "src/core/lib/gprpp/debug_location.h"
52
+ #include "src/core/lib/gprpp/orphanable.h"
53
+ #include "src/core/lib/gprpp/unique_type_name.h"
39
54
  #include "src/core/lib/iomgr/endpoint.h"
40
- #include "src/core/lib/iomgr/tcp_client.h"
55
+ #include "src/core/lib/iomgr/exec_ctx.h"
56
+ #include "src/core/lib/iomgr/resolved_address.h"
41
57
  #include "src/core/lib/resolver/resolver_registry.h"
42
- #include "src/core/lib/resource_quota/api.h"
43
58
  #include "src/core/lib/security/credentials/credentials.h"
44
59
  #include "src/core/lib/security/credentials/insecure/insecure_credentials.h"
45
60
  #include "src/core/lib/security/security_connector/security_connector.h"
46
61
  #include "src/core/lib/slice/slice_internal.h"
47
62
  #include "src/core/lib/surface/api_trace.h"
48
63
  #include "src/core/lib/surface/channel.h"
64
+ #include "src/core/lib/surface/channel_stack_type.h"
65
+ #include "src/core/lib/transport/error_utils.h"
66
+ #include "src/core/lib/transport/handshaker.h"
67
+ #include "src/core/lib/transport/handshaker_registry.h"
68
+ #include "src/core/lib/transport/tcp_connect_handshaker.h"
49
69
  #include "src/core/lib/transport/transport.h"
50
- #include "src/core/lib/uri/uri_parser.h"
70
+ #include "src/core/lib/transport/transport_fwd.h"
51
71
 
52
72
  #ifdef GPR_SUPPORT_CHANNELS_FROM_FD
53
73
 
54
74
  #include <fcntl.h>
55
75
 
76
+ #include "src/core/lib/iomgr/ev_posix.h"
56
77
  #include "src/core/lib/iomgr/tcp_client_posix.h"
57
- #include "src/core/lib/iomgr/tcp_posix.h"
58
78
 
59
79
  #endif // GPR_SUPPORT_CHANNELS_FROM_FD
60
80
 
61
81
  namespace grpc_core {
62
82
 
63
- Chttp2Connector::Chttp2Connector() {
64
- GRPC_CLOSURE_INIT(&connected_, Connected, this, grpc_schedule_on_exec_ctx);
83
+ namespace {
84
+ void NullThenSchedClosure(const DebugLocation& location, grpc_closure** closure,
85
+ grpc_error_handle error) {
86
+ grpc_closure* c = *closure;
87
+ *closure = nullptr;
88
+ ExecCtx::Run(location, c, error);
65
89
  }
90
+ } // namespace
66
91
 
67
92
  Chttp2Connector::~Chttp2Connector() {
68
93
  if (endpoint_ != nullptr) {
@@ -72,99 +97,59 @@ Chttp2Connector::~Chttp2Connector() {
72
97
 
73
98
  void Chttp2Connector::Connect(const Args& args, Result* result,
74
99
  grpc_closure* notify) {
75
- grpc_endpoint** ep;
76
100
  {
77
101
  MutexLock lock(&mu_);
78
102
  GPR_ASSERT(notify_ == nullptr);
79
103
  args_ = args;
80
104
  result_ = result;
81
105
  notify_ = notify;
82
- GPR_ASSERT(!connecting_);
83
- connecting_ = true;
84
106
  GPR_ASSERT(endpoint_ == nullptr);
85
- ep = &endpoint_;
86
107
  }
87
- // In some implementations, the closure can be flushed before
88
- // grpc_tcp_client_connect() returns, and since the closure requires access
89
- // to mu_, this can result in a deadlock (see
90
- // https://github.com/grpc/grpc/issues/16427 for details).
91
- // grpc_tcp_client_connect() will fill endpoint_ with proper contents, and we
92
- // make sure that we still exist at that point by taking a ref.
93
- Ref().release(); // Ref held by callback.
94
- grpc_tcp_client_connect(&connected_, ep, args.interested_parties,
95
- args.channel_args, args.address, args.deadline);
108
+ absl::StatusOr<std::string> address = grpc_sockaddr_to_uri(args.address);
109
+ if (!address.ok()) {
110
+ grpc_error_handle error =
111
+ GRPC_ERROR_CREATE_FROM_CPP_STRING(address.status().ToString());
112
+ NullThenSchedClosure(DEBUG_LOCATION, &notify_, error);
113
+ return;
114
+ }
115
+ absl::InlinedVector<grpc_arg, 2> args_to_add = {
116
+ grpc_channel_arg_string_create(
117
+ const_cast<char*>(GRPC_ARG_TCP_HANDSHAKER_RESOLVED_ADDRESS),
118
+ const_cast<char*>(address.value().c_str())),
119
+ grpc_channel_arg_integer_create(
120
+ const_cast<char*>(GRPC_ARG_TCP_HANDSHAKER_BIND_ENDPOINT_TO_POLLSET),
121
+ 1),
122
+ };
123
+ grpc_channel_args* channel_args = grpc_channel_args_copy_and_add(
124
+ args_.channel_args, args_to_add.data(), args_to_add.size());
125
+ handshake_mgr_ = MakeRefCounted<HandshakeManager>();
126
+ CoreConfiguration::Get().handshaker_registry().AddHandshakers(
127
+ HANDSHAKER_CLIENT, channel_args, args_.interested_parties,
128
+ handshake_mgr_.get());
129
+ Ref().release(); // Ref held by OnHandshakeDone().
130
+ handshake_mgr_->DoHandshake(nullptr /* endpoint */, channel_args,
131
+ args.deadline, nullptr /* acceptor */,
132
+ OnHandshakeDone, this);
133
+ grpc_channel_args_destroy(channel_args);
96
134
  }
97
135
 
98
136
  void Chttp2Connector::Shutdown(grpc_error_handle error) {
99
137
  MutexLock lock(&mu_);
100
138
  shutdown_ = true;
101
139
  if (handshake_mgr_ != nullptr) {
140
+ // Handshaker will also shutdown the endpoint if it exists
102
141
  handshake_mgr_->Shutdown(GRPC_ERROR_REF(error));
103
142
  }
104
- // If handshaking is not yet in progress, shutdown the endpoint.
105
- // Otherwise, the handshaker will do this for us.
106
- if (!connecting_ && endpoint_ != nullptr) {
107
- grpc_endpoint_shutdown(endpoint_, GRPC_ERROR_REF(error));
108
- }
109
143
  GRPC_ERROR_UNREF(error);
110
144
  }
111
145
 
112
- void Chttp2Connector::Connected(void* arg, grpc_error_handle error) {
113
- Chttp2Connector* self = static_cast<Chttp2Connector*>(arg);
114
- bool unref = false;
115
- {
116
- MutexLock lock(&self->mu_);
117
- GPR_ASSERT(self->connecting_);
118
- self->connecting_ = false;
119
- if (error != GRPC_ERROR_NONE || self->shutdown_) {
120
- if (error == GRPC_ERROR_NONE) {
121
- error = GRPC_ERROR_CREATE_FROM_STATIC_STRING("connector shutdown");
122
- } else {
123
- error = GRPC_ERROR_REF(error);
124
- }
125
- if (self->endpoint_ != nullptr) {
126
- grpc_endpoint_shutdown(self->endpoint_, GRPC_ERROR_REF(error));
127
- }
128
- self->result_->Reset();
129
- grpc_closure* notify = self->notify_;
130
- self->notify_ = nullptr;
131
- ExecCtx::Run(DEBUG_LOCATION, notify, error);
132
- unref = true;
133
- } else {
134
- GPR_ASSERT(self->endpoint_ != nullptr);
135
- self->StartHandshakeLocked();
136
- }
137
- }
138
- if (unref) self->Unref();
139
- }
140
-
141
- void Chttp2Connector::StartHandshakeLocked() {
142
- handshake_mgr_ = MakeRefCounted<HandshakeManager>();
143
- CoreConfiguration::Get().handshaker_registry().AddHandshakers(
144
- HANDSHAKER_CLIENT, args_.channel_args, args_.interested_parties,
145
- handshake_mgr_.get());
146
- grpc_endpoint_add_to_pollset_set(endpoint_, args_.interested_parties);
147
- handshake_mgr_->DoHandshake(endpoint_, args_.channel_args, args_.deadline,
148
- nullptr /* acceptor */, OnHandshakeDone, this);
149
- endpoint_ = nullptr; // Endpoint handed off to handshake manager.
150
- }
151
-
152
- namespace {
153
- void NullThenSchedClosure(const DebugLocation& location, grpc_closure** closure,
154
- grpc_error_handle error) {
155
- grpc_closure* c = *closure;
156
- *closure = nullptr;
157
- ExecCtx::Run(location, c, error);
158
- }
159
- } // namespace
160
-
161
146
  void Chttp2Connector::OnHandshakeDone(void* arg, grpc_error_handle error) {
162
147
  auto* args = static_cast<HandshakerArgs*>(arg);
163
148
  Chttp2Connector* self = static_cast<Chttp2Connector*>(args->user_data);
164
149
  {
165
150
  MutexLock lock(&self->mu_);
166
- if (error != GRPC_ERROR_NONE || self->shutdown_) {
167
- if (error == GRPC_ERROR_NONE) {
151
+ if (!GRPC_ERROR_IS_NONE(error) || self->shutdown_) {
152
+ if (GRPC_ERROR_IS_NONE(error)) {
168
153
  error = GRPC_ERROR_CREATE_FROM_STATIC_STRING("connector shutdown");
169
154
  // We were shut down after handshaking completed successfully, so
170
155
  // destroy the endpoint here.
@@ -221,7 +206,7 @@ void Chttp2Connector::OnReceiveSettings(void* arg, grpc_error_handle error) {
221
206
  if (!self->notify_error_.has_value()) {
222
207
  grpc_endpoint_delete_from_pollset_set(self->endpoint_,
223
208
  self->args_.interested_parties);
224
- if (error != GRPC_ERROR_NONE) {
209
+ if (!GRPC_ERROR_IS_NONE(error)) {
225
210
  // Transport got an error while waiting on SETTINGS frame.
226
211
  // TODO(yashykt): The following two lines should be moved to
227
212
  // SubchannelConnector::Result::Reset()
@@ -306,7 +291,8 @@ class Chttp2SecureClientChannelFactory : public ClientChannelFactory {
306
291
  if (channel_credentials == nullptr) {
307
292
  gpr_log(GPR_ERROR,
308
293
  "Can't create subchannel: channel credentials missing for secure "
309
- "channel.");
294
+ "channel. Got args: %s",
295
+ grpc_channel_args_string(args).c_str());
310
296
  return nullptr;
311
297
  }
312
298
  // Make sure security connector does not already exist in args.
@@ -344,29 +330,19 @@ class Chttp2SecureClientChannelFactory : public ClientChannelFactory {
344
330
  }
345
331
  };
346
332
 
347
- grpc_channel* CreateChannel(const char* target, const grpc_channel_args* args,
348
- grpc_error_handle* error) {
333
+ absl::StatusOr<RefCountedPtr<Channel>> CreateChannel(const char* target,
334
+ ChannelArgs args) {
349
335
  if (target == nullptr) {
350
336
  gpr_log(GPR_ERROR, "cannot create channel with NULL target name");
351
- if (error != nullptr) {
352
- *error = GRPC_ERROR_CREATE_FROM_STATIC_STRING("channel target is NULL");
353
- }
354
- return nullptr;
337
+ return absl::InvalidArgumentError("channel target is NULL");
355
338
  }
356
339
  // Add channel arg containing the server URI.
357
340
  std::string canonical_target =
358
341
  CoreConfiguration::Get().resolver_registry().AddDefaultPrefixIfNeeded(
359
342
  target);
360
- grpc_arg arg = grpc_channel_arg_string_create(
361
- const_cast<char*>(GRPC_ARG_SERVER_URI),
362
- const_cast<char*>(canonical_target.c_str()));
363
- const char* to_remove[] = {GRPC_ARG_SERVER_URI};
364
- grpc_channel_args* new_args =
365
- grpc_channel_args_copy_and_add_and_remove(args, to_remove, 1, &arg, 1);
366
- grpc_channel* channel = grpc_channel_create_internal(
367
- target, new_args, GRPC_CLIENT_CHANNEL, nullptr, error);
368
- grpc_channel_args_destroy(new_args);
369
- return channel;
343
+ return Channel::Create(target,
344
+ args.Set(GRPC_ARG_SERVER_URI, canonical_target),
345
+ GRPC_CLIENT_CHANNEL, nullptr);
370
346
  }
371
347
 
372
348
  } // namespace
@@ -389,33 +365,30 @@ void FactoryInit() {
389
365
  // - perform handshakes
390
366
  grpc_channel* grpc_channel_create(const char* target,
391
367
  grpc_channel_credentials* creds,
392
- const grpc_channel_args* args) {
368
+ const grpc_channel_args* c_args) {
393
369
  grpc_core::ExecCtx exec_ctx;
394
370
  GRPC_API_TRACE("grpc_secure_channel_create(target=%s, creds=%p, args=%p)", 3,
395
- (target, (void*)creds, (void*)args));
396
- args = grpc_core::CoreConfiguration::Get()
397
- .channel_args_preconditioning()
398
- .PreconditionChannelArgs(args);
371
+ (target, (void*)creds, (void*)c_args));
399
372
  grpc_channel* channel = nullptr;
400
373
  grpc_error_handle error = GRPC_ERROR_NONE;
401
374
  if (creds != nullptr) {
402
375
  // Add channel args containing the client channel factory and channel
403
376
  // credentials.
404
377
  gpr_once_init(&g_factory_once, FactoryInit);
405
- grpc_arg channel_factory_arg =
406
- grpc_core::ClientChannelFactory::CreateChannelArg(g_factory);
407
- grpc_arg args_to_add[] = {channel_factory_arg,
408
- grpc_channel_credentials_to_arg(creds)};
409
- const char* arg_to_remove = channel_factory_arg.key;
410
- grpc_channel_args* new_args = grpc_channel_args_copy_and_add_and_remove(
411
- args, &arg_to_remove, 1, args_to_add, GPR_ARRAY_SIZE(args_to_add));
412
- new_args = creds->update_arguments(new_args);
378
+ grpc_core::ChannelArgs args =
379
+ creds->update_arguments(grpc_core::CoreConfiguration::Get()
380
+ .channel_args_preconditioning()
381
+ .PreconditionChannelArgs(c_args)
382
+ .SetObject(creds->Ref())
383
+ .SetObject(g_factory));
413
384
  // Create channel.
414
- channel = grpc_core::CreateChannel(target, new_args, &error);
415
- // Clean up.
416
- grpc_channel_args_destroy(new_args);
385
+ auto r = grpc_core::CreateChannel(target, args);
386
+ if (r.ok()) {
387
+ channel = r->release()->c_ptr();
388
+ } else {
389
+ error = absl_status_to_grpc_error(r.status());
390
+ }
417
391
  }
418
- grpc_channel_args_destroy(args);
419
392
  if (channel == nullptr) {
420
393
  intptr_t integer;
421
394
  grpc_status_code status = GRPC_STATUS_INTERNAL;
@@ -439,19 +412,18 @@ grpc_channel* grpc_channel_create_from_fd(const char* target, int fd,
439
412
  (target, fd, creds, args));
440
413
  // For now, we only support insecure channel credentials.
441
414
  if (creds == nullptr ||
442
- creds->type() != grpc_core::InsecureServerCredentials::Type()) {
415
+ creds->type() != grpc_core::InsecureCredentials::Type()) {
443
416
  return grpc_lame_client_channel_create(
444
417
  target, GRPC_STATUS_INTERNAL,
445
418
  "Failed to create client channel due to invalid creds");
446
419
  }
447
- grpc_arg default_authority_arg = grpc_channel_arg_string_create(
448
- const_cast<char*>(GRPC_ARG_DEFAULT_AUTHORITY),
449
- const_cast<char*>("test.authority"));
450
- args = grpc_channel_args_copy_and_add(args, &default_authority_arg, 1);
451
- const grpc_channel_args* final_args = grpc_core::CoreConfiguration::Get()
452
- .channel_args_preconditioning()
453
- .PreconditionChannelArgs(args);
454
- grpc_channel_args_destroy(args);
420
+ const grpc_channel_args* final_args =
421
+ grpc_core::CoreConfiguration::Get()
422
+ .channel_args_preconditioning()
423
+ .PreconditionChannelArgs(args)
424
+ .SetIfUnset(GRPC_ARG_DEFAULT_AUTHORITY, "test.authority")
425
+ .SetObject(creds->Ref())
426
+ .ToC();
455
427
 
456
428
  int flags = fcntl(fd, F_GETFL, 0);
457
429
  GPR_ASSERT(fcntl(fd, F_SETFL, flags | O_NONBLOCK) == 0);
@@ -460,26 +432,20 @@ grpc_channel* grpc_channel_create_from_fd(const char* target, int fd,
460
432
  grpc_transport* transport =
461
433
  grpc_create_chttp2_transport(final_args, client, true);
462
434
  GPR_ASSERT(transport);
463
- grpc_error_handle error = GRPC_ERROR_NONE;
464
- grpc_channel* channel = grpc_channel_create_internal(
465
- target, final_args, GRPC_CLIENT_DIRECT_CHANNEL, transport, &error);
435
+ auto channel = grpc_core::Channel::Create(
436
+ target, grpc_core::ChannelArgs::FromC(final_args),
437
+ GRPC_CLIENT_DIRECT_CHANNEL, transport);
466
438
  grpc_channel_args_destroy(final_args);
467
- if (channel != nullptr) {
439
+ if (channel.ok()) {
468
440
  grpc_chttp2_transport_start_reading(transport, nullptr, nullptr, nullptr);
469
441
  grpc_core::ExecCtx::Get()->Flush();
442
+ return channel->release()->c_ptr();
470
443
  } else {
471
- intptr_t integer;
472
- grpc_status_code status = GRPC_STATUS_INTERNAL;
473
- if (grpc_error_get_int(error, GRPC_ERROR_INT_GRPC_STATUS, &integer)) {
474
- status = static_cast<grpc_status_code>(integer);
475
- }
476
- GRPC_ERROR_UNREF(error);
477
444
  grpc_transport_destroy(transport);
478
- channel = grpc_lame_client_channel_create(
479
- target, status, "Failed to create client channel");
445
+ return grpc_lame_client_channel_create(
446
+ target, static_cast<grpc_status_code>(channel.status().code()),
447
+ "Failed to create client channel");
480
448
  }
481
-
482
- return channel;
483
449
  }
484
450
 
485
451
  #else // !GPR_SUPPORT_CHANNELS_FROM_FD
@@ -21,23 +21,27 @@
21
21
 
22
22
  #include <grpc/support/port_platform.h>
23
23
 
24
+ #include "absl/types/optional.h"
25
+
24
26
  #include "src/core/ext/filters/client_channel/connector.h"
25
- #include "src/core/lib/channel/handshaker.h"
26
- #include "src/core/lib/channel/handshaker_registry.h"
27
+ #include "src/core/lib/gprpp/ref_counted_ptr.h"
28
+ #include "src/core/lib/gprpp/sync.h"
29
+ #include "src/core/lib/iomgr/closure.h"
30
+ #include "src/core/lib/iomgr/endpoint.h"
31
+ #include "src/core/lib/iomgr/error.h"
32
+ #include "src/core/lib/iomgr/timer.h"
33
+ #include "src/core/lib/transport/handshaker.h"
27
34
 
28
35
  namespace grpc_core {
29
36
 
30
37
  class Chttp2Connector : public SubchannelConnector {
31
38
  public:
32
- Chttp2Connector();
33
39
  ~Chttp2Connector() override;
34
40
 
35
41
  void Connect(const Args& args, Result* result, grpc_closure* notify) override;
36
42
  void Shutdown(grpc_error_handle error) override;
37
43
 
38
44
  private:
39
- static void Connected(void* arg, grpc_error_handle error);
40
- void StartHandshakeLocked();
41
45
  static void OnHandshakeDone(void* arg, grpc_error_handle error);
42
46
  static void OnReceiveSettings(void* arg, grpc_error_handle error);
43
47
  static void OnTimeout(void* arg, grpc_error_handle error);
@@ -58,11 +62,9 @@ class Chttp2Connector : public SubchannelConnector {
58
62
  Result* result_ = nullptr;
59
63
  grpc_closure* notify_ = nullptr;
60
64
  bool shutdown_ = false;
61
- bool connecting_ = false;
62
65
  // Holds the endpoint when first created before being handed off to
63
66
  // the handshake manager, and then again after handshake is done.
64
67
  grpc_endpoint* endpoint_ = nullptr;
65
- grpc_closure connected_;
66
68
  grpc_closure on_receive_settings_;
67
69
  grpc_timer timer_;
68
70
  grpc_closure on_timeout_;
@@ -24,11 +24,20 @@
24
24
  #include <limits.h>
25
25
  #include <string.h>
26
26
 
27
+ #include <algorithm>
28
+ #include <map>
29
+ #include <memory>
30
+ #include <string>
31
+ #include <utility>
27
32
  #include <vector>
28
33
 
29
- #include "absl/strings/match.h"
34
+ #include "absl/base/thread_annotations.h"
35
+ #include "absl/memory/memory.h"
36
+ #include "absl/status/status.h"
37
+ #include "absl/status/statusor.h"
30
38
  #include "absl/strings/str_cat.h"
31
39
  #include "absl/strings/str_format.h"
40
+ #include "absl/strings/string_view.h"
32
41
  #include "absl/strings/strip.h"
33
42
 
34
43
  #include <grpc/grpc.h>
@@ -36,38 +45,53 @@
36
45
  #include <grpc/impl/codegen/grpc_types.h>
37
46
  #include <grpc/support/alloc.h>
38
47
  #include <grpc/support/log.h>
39
- #include <grpc/support/sync.h>
48
+ #include <grpc/support/time.h>
40
49
 
41
- #include "src/core/ext/filters/http/server/http_server_filter.h"
42
50
  #include "src/core/ext/transport/chttp2/transport/chttp2_transport.h"
51
+ #include "src/core/ext/transport/chttp2/transport/frame.h"
43
52
  #include "src/core/ext/transport/chttp2/transport/internal.h"
44
53
  #include "src/core/lib/address_utils/sockaddr_utils.h"
45
54
  #include "src/core/lib/channel/channel_args.h"
46
- #include "src/core/lib/channel/handshaker.h"
55
+ #include "src/core/lib/channel/channelz.h"
47
56
  #include "src/core/lib/config/core_configuration.h"
48
- #include "src/core/lib/gprpp/ref_counted.h"
57
+ #include "src/core/lib/debug/trace.h"
58
+ #include "src/core/lib/gpr/useful.h"
59
+ #include "src/core/lib/gprpp/debug_location.h"
60
+ #include "src/core/lib/gprpp/orphanable.h"
49
61
  #include "src/core/lib/gprpp/ref_counted_ptr.h"
62
+ #include "src/core/lib/gprpp/sync.h"
63
+ #include "src/core/lib/gprpp/time.h"
64
+ #include "src/core/lib/gprpp/unique_type_name.h"
65
+ #include "src/core/lib/iomgr/closure.h"
50
66
  #include "src/core/lib/iomgr/endpoint.h"
67
+ #include "src/core/lib/iomgr/iomgr_fwd.h"
68
+ #include "src/core/lib/iomgr/pollset.h"
69
+ #include "src/core/lib/iomgr/pollset_set.h"
51
70
  #include "src/core/lib/iomgr/resolve_address.h"
71
+ #include "src/core/lib/iomgr/resolved_address.h"
52
72
  #include "src/core/lib/iomgr/tcp_server.h"
73
+ #include "src/core/lib/iomgr/timer.h"
53
74
  #include "src/core/lib/iomgr/unix_sockets_posix.h"
54
75
  #include "src/core/lib/resource_quota/api.h"
55
76
  #include "src/core/lib/resource_quota/memory_quota.h"
56
- #include "src/core/lib/security/context/security_context.h"
77
+ #include "src/core/lib/resource_quota/resource_quota.h"
57
78
  #include "src/core/lib/security/credentials/credentials.h"
58
79
  #include "src/core/lib/security/credentials/insecure/insecure_credentials.h"
80
+ #include "src/core/lib/security/security_connector/security_connector.h"
59
81
  #include "src/core/lib/slice/slice_internal.h"
60
82
  #include "src/core/lib/surface/api_trace.h"
61
83
  #include "src/core/lib/surface/server.h"
62
84
  #include "src/core/lib/transport/error_utils.h"
85
+ #include "src/core/lib/transport/handshaker.h"
86
+ #include "src/core/lib/transport/handshaker_registry.h"
87
+ #include "src/core/lib/transport/transport.h"
88
+ #include "src/core/lib/transport/transport_fwd.h"
63
89
  #include "src/core/lib/uri/uri_parser.h"
64
90
 
65
91
  #ifdef GPR_SUPPORT_CHANNELS_FROM_FD
66
-
92
+ #include "src/core/lib/iomgr/ev_posix.h"
67
93
  #include "src/core/lib/iomgr/exec_ctx.h"
68
94
  #include "src/core/lib/iomgr/tcp_posix.h"
69
- #include "src/core/lib/surface/completion_queue.h"
70
-
71
95
  #endif // GPR_SUPPORT_CHANNELS_FROM_FD
72
96
 
73
97
  namespace grpc_core {
@@ -301,7 +325,7 @@ void Chttp2ServerListener::ConfigFetcherWatcher::UpdateConnectionManager(
301
325
  int port_temp;
302
326
  grpc_error_handle error = grpc_tcp_server_add_port(
303
327
  listener_->tcp_server_, &listener_->resolved_address_, &port_temp);
304
- if (error != GRPC_ERROR_NONE) {
328
+ if (!GRPC_ERROR_IS_NONE(error)) {
305
329
  GRPC_ERROR_UNREF(error);
306
330
  gpr_log(GPR_ERROR, "Error adding port to server: %s",
307
331
  grpc_error_std_string(error).c_str());
@@ -422,11 +446,11 @@ void Chttp2ServerListener::ActiveConnection::HandshakingState::OnHandshakeDone(
422
446
  bool cleanup_connection = false;
423
447
  {
424
448
  MutexLock connection_lock(&self->connection_->mu_);
425
- if (error != GRPC_ERROR_NONE || self->connection_->shutdown_) {
449
+ if (!GRPC_ERROR_IS_NONE(error) || self->connection_->shutdown_) {
426
450
  std::string error_str = grpc_error_std_string(error);
427
451
  gpr_log(GPR_DEBUG, "Handshaking failed: %s", error_str.c_str());
428
452
  cleanup_connection = true;
429
- if (error == GRPC_ERROR_NONE && args->endpoint != nullptr) {
453
+ if (GRPC_ERROR_IS_NONE(error) && args->endpoint != nullptr) {
430
454
  // We were shut down or stopped serving after handshaking completed
431
455
  // successfully, so destroy the endpoint here.
432
456
  // TODO(ctiller): It is currently necessary to shutdown endpoints
@@ -450,7 +474,7 @@ void Chttp2ServerListener::ActiveConnection::HandshakingState::OnHandshakeDone(
450
474
  self->connection_->listener_->server_->SetupTransport(
451
475
  transport, self->accepting_pollset_, args->args,
452
476
  grpc_chttp2_transport_get_socket_node(transport));
453
- if (channel_init_err == GRPC_ERROR_NONE) {
477
+ if (GRPC_ERROR_IS_NONE(channel_init_err)) {
454
478
  // Use notify_on_receive_settings callback to enforce the
455
479
  // handshake deadline.
456
480
  // Note: The reinterpret_cast<>s here are safe, because
@@ -629,7 +653,7 @@ void Chttp2ServerListener::ActiveConnection::OnDrainGraceTimeExpiry(
629
653
  ActiveConnection* self = static_cast<ActiveConnection*>(arg);
630
654
  // If the drain_grace_timer_ was not cancelled, disconnect the transport
631
655
  // immediately.
632
- if (error == GRPC_ERROR_NONE) {
656
+ if (GRPC_ERROR_IS_NONE(error)) {
633
657
  grpc_chttp2_transport* transport = nullptr;
634
658
  {
635
659
  MutexLock lock(&self->mu_);
@@ -659,29 +683,33 @@ grpc_error_handle Chttp2ServerListener::Create(
659
683
  listener = new Chttp2ServerListener(server, args, args_modifier);
660
684
  error = grpc_tcp_server_create(&listener->tcp_server_shutdown_complete_,
661
685
  args, &listener->tcp_server_);
662
- if (error != GRPC_ERROR_NONE) return error;
686
+ if (!GRPC_ERROR_IS_NONE(error)) return error;
663
687
  if (server->config_fetcher() != nullptr) {
664
688
  listener->resolved_address_ = *addr;
665
689
  // TODO(yashykt): Consider binding so as to be able to return the port
666
690
  // number.
667
691
  } else {
668
692
  error = grpc_tcp_server_add_port(listener->tcp_server_, addr, port_num);
669
- if (error != GRPC_ERROR_NONE) return error;
693
+ if (!GRPC_ERROR_IS_NONE(error)) return error;
670
694
  }
671
695
  // Create channelz node.
672
696
  if (grpc_channel_args_find_bool(args, GRPC_ARG_ENABLE_CHANNELZ,
673
697
  GRPC_ENABLE_CHANNELZ_DEFAULT)) {
674
- std::string string_address = grpc_sockaddr_to_uri(addr);
698
+ auto string_address = grpc_sockaddr_to_uri(addr);
699
+ if (!string_address.ok()) {
700
+ return GRPC_ERROR_CREATE_FROM_CPP_STRING(
701
+ string_address.status().ToString());
702
+ }
675
703
  listener->channelz_listen_socket_ =
676
704
  MakeRefCounted<channelz::ListenSocketNode>(
677
- string_address.c_str(),
678
- absl::StrFormat("chttp2 listener %s", string_address.c_str()));
705
+ *string_address,
706
+ absl::StrCat("chttp2 listener ", *string_address));
679
707
  }
680
708
  // Register with the server only upon success
681
709
  server->AddListener(OrphanablePtr<Server::ListenerInterface>(listener));
682
710
  return GRPC_ERROR_NONE;
683
711
  }();
684
- if (error != GRPC_ERROR_NONE) {
712
+ if (!GRPC_ERROR_IS_NONE(error)) {
685
713
  if (listener != nullptr) {
686
714
  if (listener->tcp_server_ != nullptr) {
687
715
  // listener is deleted when tcp_server_ is shutdown.
@@ -703,7 +731,7 @@ grpc_error_handle Chttp2ServerListener::CreateWithAcceptor(
703
731
  new Chttp2ServerListener(server, args, args_modifier);
704
732
  grpc_error_handle error = grpc_tcp_server_create(
705
733
  &listener->tcp_server_shutdown_complete_, args, &listener->tcp_server_);
706
- if (error != GRPC_ERROR_NONE) {
734
+ if (!GRPC_ERROR_IS_NONE(error)) {
707
735
  delete listener;
708
736
  return error;
709
737
  }
@@ -744,7 +772,8 @@ void Chttp2ServerListener::Start(
744
772
  auto watcher = absl::make_unique<ConfigFetcherWatcher>(Ref());
745
773
  config_fetcher_watcher_ = watcher.get();
746
774
  server_->config_fetcher()->StartWatch(
747
- grpc_sockaddr_to_string(&resolved_address_, false), std::move(watcher));
775
+ grpc_sockaddr_to_string(&resolved_address_, false).value(),
776
+ std::move(watcher));
748
777
  } else {
749
778
  {
750
779
  MutexLock lock(&mu_);
@@ -803,7 +832,7 @@ void Chttp2ServerListener::OnAccept(void* arg, grpc_endpoint* tcp,
803
832
  }
804
833
  grpc_error_handle error = GRPC_ERROR_NONE;
805
834
  args = self->args_modifier_(*args_result, &error);
806
- if (error != GRPC_ERROR_NONE) {
835
+ if (!GRPC_ERROR_IS_NONE(error)) {
807
836
  gpr_log(GPR_DEBUG, "Closing connection: %s",
808
837
  grpc_error_std_string(error).c_str());
809
838
  endpoint_cleanup(error);
@@ -930,7 +959,7 @@ grpc_error_handle Chttp2ServerAddPort(Server* server, const char* addr,
930
959
  error = Chttp2ServerListener::Create(server, &addr,
931
960
  grpc_channel_args_copy(args),
932
961
  args_modifier, &port_temp);
933
- if (error != GRPC_ERROR_NONE) {
962
+ if (!GRPC_ERROR_IS_NONE(error)) {
934
963
  error_list.push_back(error);
935
964
  } else {
936
965
  if (*port_num == -1) {
@@ -963,7 +992,7 @@ grpc_error_handle Chttp2ServerAddPort(Server* server, const char* addr,
963
992
  GRPC_ERROR_UNREF(error);
964
993
  }
965
994
  grpc_channel_args_destroy(args);
966
- if (error != GRPC_ERROR_NONE) *port_num = 0;
995
+ if (!GRPC_ERROR_IS_NONE(error)) *port_num = 0;
967
996
  return error;
968
997
  }
969
998
 
@@ -984,7 +1013,7 @@ grpc_channel_args* ModifyArgsForConnection(grpc_channel_args* args,
984
1013
  if (security_connector == nullptr) {
985
1014
  *error = GRPC_ERROR_CREATE_FROM_CPP_STRING(
986
1015
  absl::StrCat("Unable to create secure server with credentials of type ",
987
- server_credentials->type()));
1016
+ server_credentials->type().name()));
988
1017
  return args;
989
1018
  }
990
1019
  grpc_arg arg_to_add =
@@ -1033,7 +1062,7 @@ int grpc_server_add_http2_port(grpc_server* server, const char* addr,
1033
1062
  if (sc == nullptr) {
1034
1063
  err = GRPC_ERROR_CREATE_FROM_CPP_STRING(absl::StrCat(
1035
1064
  "Unable to create secure server with credentials of type ",
1036
- creds->type()));
1065
+ creds->type().name()));
1037
1066
  goto done;
1038
1067
  }
1039
1068
  grpc_arg args_to_add[2];
@@ -1047,7 +1076,7 @@ int grpc_server_add_http2_port(grpc_server* server, const char* addr,
1047
1076
  ModifyArgsForConnection, &port_num);
1048
1077
  done:
1049
1078
  sc.reset(DEBUG_LOCATION, "server");
1050
- if (err != GRPC_ERROR_NONE) {
1079
+ if (!GRPC_ERROR_IS_NONE(err)) {
1051
1080
  gpr_log(GPR_ERROR, "%s", grpc_error_std_string(err).c_str());
1052
1081
 
1053
1082
  GRPC_ERROR_UNREF(err);
@@ -1078,7 +1107,7 @@ void grpc_server_add_channel_from_fd(grpc_server* server, int fd,
1078
1107
  );
1079
1108
  grpc_error_handle error =
1080
1109
  core_server->SetupTransport(transport, nullptr, server_args, nullptr);
1081
- if (error == GRPC_ERROR_NONE) {
1110
+ if (GRPC_ERROR_IS_NONE(error)) {
1082
1111
  for (grpc_pollset* pollset : core_server->pollsets()) {
1083
1112
  grpc_endpoint_add_to_pollset(server_endpoint, pollset);
1084
1113
  }